Mercurial > vim
diff src/list.c @ 23604:1816ea68c022 v8.2.2344
patch 8.2.2344: using inclusive index for slice is not always desired
Commit: https://github.com/vim/vim/commit/6601b62943a19d4f8818c3638440663d67a17b6a
Author: Bram Moolenaar <Bram@vim.org>
Date: Wed Jan 13 21:47:15 2021 +0100
patch 8.2.2344: using inclusive index for slice is not always desired
Problem: Using inclusive index for slice is not always desired.
Solution: Add the slice() method, which has an exclusive index. (closes
#7408)
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Wed, 13 Jan 2021 22:00:04 +0100 |
parents | 510088f8c66f |
children | 5d77a7587927 |
line wrap: on
line diff
--- a/src/list.c +++ b/src/list.c @@ -905,14 +905,15 @@ list_slice(list_T *ol, long n1, long n2) list_slice_or_index( list_T *list, int range, - long n1_arg, - long n2_arg, + varnumber_T n1_arg, + varnumber_T n2_arg, + int exclusive, typval_T *rettv, int verbose) { long len = list_len(list); - long n1 = n1_arg; - long n2 = n2_arg; + varnumber_T n1 = n1_arg; + varnumber_T n2 = n2_arg; typval_T var1; if (n1 < 0) @@ -936,7 +937,9 @@ list_slice_or_index( if (n2 < 0) n2 = len + n2; else if (n2 >= len) - n2 = len - 1; + n2 = len - (exclusive ? 0 : 1); + if (exclusive) + --n2; if (n2 < 0 || n2 + 1 < n1) n2 = -1; l = list_slice(list, n1, n2);