mirror of
https://github.com/neovim/neovim.git
synced 2025-09-05 19:08:15 +00:00
vim-patch:8.2.2466: max() and min() can give many error messages
Problem: Max() and min() can give many error messages.
Solution: Bail out at the first error. (closes vim/vim#1039, closes vim/vim#7778)
ab65fc77c5
Co-authored-by: Bram Moolenaar <Bram@vim.org>
This commit is contained in:
@@ -5245,7 +5245,7 @@ static void max_min(const typval_T *const tv, typval_T *const rettv, const bool
|
||||
TV_LIST_ITER_CONST(tv->vval.v_list, li, {
|
||||
const varnumber_T i = tv_get_number_chk(TV_LIST_ITEM_TV(li), &error);
|
||||
if (error) {
|
||||
return;
|
||||
return; // type error; errmsg already given
|
||||
}
|
||||
if (domax ? i > n : i < n) {
|
||||
n = i;
|
||||
@@ -5258,7 +5258,7 @@ static void max_min(const typval_T *const tv, typval_T *const rettv, const bool
|
||||
TV_DICT_ITER(tv->vval.v_dict, di, {
|
||||
const varnumber_T i = tv_get_number_chk(&di->di_tv, &error);
|
||||
if (error) {
|
||||
return;
|
||||
return; // type error; errmsg already given
|
||||
}
|
||||
if (domax ? i > n : i < n) {
|
||||
n = i;
|
||||
@@ -5268,6 +5268,7 @@ static void max_min(const typval_T *const tv, typval_T *const rettv, const bool
|
||||
semsg(_(e_listdictarg), domax ? "max()" : "min()");
|
||||
return;
|
||||
}
|
||||
|
||||
rettv->vval.v_number = n;
|
||||
}
|
||||
|
||||
|
@@ -110,6 +110,10 @@ func Test_max()
|
||||
|
||||
call assert_fails('call max(1)', 'E712:')
|
||||
" call assert_fails('call max(v:none)', 'E712:')
|
||||
|
||||
" check we only get one error
|
||||
call assert_fails('call max([#{}, [1]])', ['E728:', 'E728:'])
|
||||
call assert_fails('call max(#{a: {}, b: [1]})', ['E728:', 'E728:'])
|
||||
endfunc
|
||||
|
||||
func Test_min()
|
||||
@@ -123,6 +127,10 @@ func Test_min()
|
||||
|
||||
call assert_fails('call min(1)', 'E712:')
|
||||
" call assert_fails('call min(v:none)', 'E712:')
|
||||
|
||||
" check we only get one error
|
||||
call assert_fails('call min([[1], #{}])', ['E745:', 'E745:'])
|
||||
call assert_fails('call min(#{a: [1], b: #{}})', ['E745:', 'E745:'])
|
||||
endfunc
|
||||
|
||||
func Test_strwidth()
|
||||
|
Reference in New Issue
Block a user