mirror of
https://github.com/vim/vim.git
synced 2025-07-26 11:04:33 -04:00
patch 7.4.1123
Problem: Using ":argadd" when there are no arguments results in the second argument to be the current one. (Yegappan Lakshmanan) Solution: Correct the w_arg_idx value.
This commit is contained in:
parent
42c9cfa7f4
commit
a24f0a550f
@ -2836,6 +2836,7 @@ alist_add_list(count, files, after)
|
|||||||
int after; /* where to add: 0 = before first one */
|
int after; /* where to add: 0 = before first one */
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
int old_argcount = ARGCOUNT;
|
||||||
|
|
||||||
if (ga_grow(&ALIST(curwin)->al_ga, count) == OK)
|
if (ga_grow(&ALIST(curwin)->al_ga, count) == OK)
|
||||||
{
|
{
|
||||||
@ -2852,8 +2853,8 @@ alist_add_list(count, files, after)
|
|||||||
ARGLIST[after + i].ae_fnum = buflist_add(files[i], BLN_LISTED);
|
ARGLIST[after + i].ae_fnum = buflist_add(files[i], BLN_LISTED);
|
||||||
}
|
}
|
||||||
ALIST(curwin)->al_ga.ga_len += count;
|
ALIST(curwin)->al_ga.ga_len += count;
|
||||||
if (curwin->w_arg_idx >= after)
|
if (old_argcount > 0 && curwin->w_arg_idx >= after)
|
||||||
++curwin->w_arg_idx;
|
curwin->w_arg_idx += count;
|
||||||
return after;
|
return after;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,3 +20,55 @@ func Test_argidx()
|
|||||||
1argdelete
|
1argdelete
|
||||||
call assert_equal(0, argidx())
|
call assert_equal(0, argidx())
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_argadd()
|
||||||
|
%argdelete
|
||||||
|
argadd a b c
|
||||||
|
call assert_equal(0, argidx())
|
||||||
|
|
||||||
|
%argdelete
|
||||||
|
argadd a
|
||||||
|
call assert_equal(0, argidx())
|
||||||
|
argadd b c d
|
||||||
|
call assert_equal(0, argidx())
|
||||||
|
|
||||||
|
call Init_abc()
|
||||||
|
argadd x
|
||||||
|
call Assert_argc(['a', 'b', 'x', 'c'])
|
||||||
|
call assert_equal(1, argidx())
|
||||||
|
|
||||||
|
call Init_abc()
|
||||||
|
0argadd x
|
||||||
|
call Assert_argc(['x', 'a', 'b', 'c'])
|
||||||
|
call assert_equal(2, argidx())
|
||||||
|
|
||||||
|
call Init_abc()
|
||||||
|
1argadd x
|
||||||
|
call Assert_argc(['a', 'x', 'b', 'c'])
|
||||||
|
call assert_equal(2, argidx())
|
||||||
|
|
||||||
|
call Init_abc()
|
||||||
|
$argadd x
|
||||||
|
call Assert_argc(['a', 'b', 'c', 'x'])
|
||||||
|
call assert_equal(1, argidx())
|
||||||
|
|
||||||
|
call Init_abc()
|
||||||
|
$argadd x
|
||||||
|
+2argadd y
|
||||||
|
call Assert_argc(['a', 'b', 'c', 'x', 'y'])
|
||||||
|
call assert_equal(1, argidx())
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
func Init_abc()
|
||||||
|
args a b c
|
||||||
|
next
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
func Assert_argc(l)
|
||||||
|
call assert_equal(len(a:l), argc())
|
||||||
|
let i = 0
|
||||||
|
while i < len(a:l) && i < argc()
|
||||||
|
call assert_equal(a:l[i], argv(i))
|
||||||
|
let i += 1
|
||||||
|
endwhile
|
||||||
|
endfunc
|
||||||
|
@ -741,6 +741,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 */
|
||||||
|
/**/
|
||||||
|
1123,
|
||||||
/**/
|
/**/
|
||||||
1122,
|
1122,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user