Problem: Using ":%argdel" while the argument list is already empty gives an
error. (Pavol Juhas)
Solution: Don't give an error. (closes #1546)
if (eap->line2 > ARGCOUNT)
eap->line2 = ARGCOUNT;
n = eap->line2 - eap->line1 + 1;
- if (*eap->arg != NUL || n <= 0)
+ if (*eap->arg != NUL)
+ /* Can't have both a range and an argument. */
EMSG(_(e_invarg));
+ else if (n <= 0)
+ {
+ /* Don't give an error for ":%argdel" if the list is empty. */
+ if (eap->line1 != 1 || eap->line2 != 0)
+ EMSG(_(e_invrange));
+ }
else
{
for (i = eap->line1; i <= eap->line2; ++i)
call assert_equal(2, argidx())
%argdelete
call assert_equal(0, argidx())
+ " doing it again doesn't result in an error
+ %argdelete
+ call assert_equal(0, argidx())
+ call assert_fails('2argdelete', 'E16:')
args a b c
call assert_equal(0, argidx())
static int included_patches[] =
{ /* Add new patch number below this line */
+/**/
+ 439,
/**/
438,
/**/