Mercurial > vim
diff src/userfunc.c @ 19888:435726a03481 v8.2.0500
patch 8.2.0500: using the same loop in many places
Commit: https://github.com/vim/vim/commit/aeea72151c31d686bcbb7b06d895006d7363585c
Author: Bram Moolenaar <Bram@vim.org>
Date: Thu Apr 2 18:50:46 2020 +0200
patch 8.2.0500: using the same loop in many places
Problem: Using the same loop in many places.
Solution: Define more FOR_ALL macros. (Yegappan Lakshmanan, closes https://github.com/vim/vim/issues/5339)
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Thu, 02 Apr 2020 19:00:05 +0200 |
parents | 4d033d36ba23 |
children | 5feb426d2ea1 |
line wrap: on
line diff
--- a/src/userfunc.c +++ b/src/userfunc.c @@ -792,7 +792,7 @@ free_funccal_contents(funccall_T *fc) vars_clear(&fc->l_avars.dv_hashtab); // Free the a:000 variables. - for (li = fc->l_varlist.lv_first; li != NULL; li = li->li_next) + FOR_ALL_LIST_ITEMS(&fc->l_varlist, li) clear_tv(&li->li_tv); free_funccal(fc); @@ -851,7 +851,7 @@ cleanup_function_call(funccall_T *fc) free_fc = FALSE; // Make a copy of the a:000 items, since we didn't do that above. - for (li = fc->l_varlist.lv_first; li != NULL; li = li->li_next) + FOR_ALL_LIST_ITEMS(&fc->l_varlist, li) copy_tv(&li->li_tv, &li->li_tv); } @@ -1640,7 +1640,7 @@ func_call( int r = 0; range_list_materialize(l); - for (item = l->lv_first; item != NULL; item = item->li_next) + FOR_ALL_LIST_ITEMS(args->vval.v_list, item) { if (argc == MAX_FUNC_ARGS - (partial == NULL ? 0 : partial->pt_argc)) {