Mercurial > vim
comparison src/ex_cmds2.c @ 11103:3335c3c75611 v8.0.0439
patch 8.0.0439: ":%argdel" gives an error for an empty arglist
commit https://github.com/vim/vim/commit/69a92fb5aecdf2f9d5f6947790b18991b22d0e4c
Author: Bram Moolenaar <Bram@vim.org>
Date: Thu Mar 9 15:58:30 2017 +0100
patch 8.0.0439: ":%argdel" gives an error for an empty arglist
Problem: Using ":%argdel" while the argument list is already empty gives an
error. (Pavol Juhas)
Solution: Don't give an error. (closes #1546)
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Thu, 09 Mar 2017 16:00:05 +0100 |
parents | 437cf0fe2138 |
children | 506f5d8b7d8b |
comparison
equal
deleted
inserted
replaced
11102:85c5d024d301 | 11103:3335c3c75611 |
---|---|
2830 { | 2830 { |
2831 /* ":1,4argdel": Delete all arguments in the range. */ | 2831 /* ":1,4argdel": Delete all arguments in the range. */ |
2832 if (eap->line2 > ARGCOUNT) | 2832 if (eap->line2 > ARGCOUNT) |
2833 eap->line2 = ARGCOUNT; | 2833 eap->line2 = ARGCOUNT; |
2834 n = eap->line2 - eap->line1 + 1; | 2834 n = eap->line2 - eap->line1 + 1; |
2835 if (*eap->arg != NUL || n <= 0) | 2835 if (*eap->arg != NUL) |
2836 /* Can't have both a range and an argument. */ | |
2836 EMSG(_(e_invarg)); | 2837 EMSG(_(e_invarg)); |
2838 else if (n <= 0) | |
2839 { | |
2840 /* Don't give an error for ":%argdel" if the list is empty. */ | |
2841 if (eap->line1 != 1 || eap->line2 != 0) | |
2842 EMSG(_(e_invrange)); | |
2843 } | |
2837 else | 2844 else |
2838 { | 2845 { |
2839 for (i = eap->line1; i <= eap->line2; ++i) | 2846 for (i = eap->line1; i <= eap->line2; ++i) |
2840 vim_free(ARGLIST[i - 1].ae_fname); | 2847 vim_free(ARGLIST[i - 1].ae_fname); |
2841 mch_memmove(ARGLIST + eap->line1 - 1, ARGLIST + eap->line2, | 2848 mch_memmove(ARGLIST + eap->line1 - 1, ARGLIST + eap->line2, |