diff options
author | Bram Moolenaar <Bram@vim.org> | 2021-04-17 21:22:49 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2021-04-17 21:22:49 +0200 |
commit | f7e92aae1581203306a340b4c0059cc74adea9d6 (patch) | |
tree | f8b79fac3095e0440114f421ed10ca4c9d785408 | |
parent | d23b714d8b9ed8e16ef553098acc6da0979e94fc (diff) | |
download | vim-git-f7e92aae1581203306a340b4c0059cc74adea9d6.tar.gz |
patch 8.2.2779: memory access error in remove() for blobv8.2.2779
Problem: Memory access error in remove() for blob.
Solution: Adjust length for memmove().
-rw-r--r-- | src/blob.c | 5 | ||||
-rw-r--r-- | src/version.c | 2 |
2 files changed, 5 insertions, 2 deletions
diff --git a/src/blob.c b/src/blob.c index 9f5977707..4685dc97c 100644 --- a/src/blob.c +++ b/src/blob.c @@ -444,7 +444,7 @@ blob_remove(typval_T *argvars, typval_T *rettv) { blob_T *blob; - // Remove range of items, return list with values. + // Remove range of items, return blob with values. end = (long)tv_get_number_chk(&argvars[2], &error); if (error) return; @@ -472,7 +472,8 @@ blob_remove(typval_T *argvars, typval_T *rettv) rettv->v_type = VAR_BLOB; rettv->vval.v_blob = blob; - mch_memmove(p + idx, p + end + 1, (size_t)(len - end)); + if (len - end - 1 > 0) + mch_memmove(p + idx, p + end + 1, (size_t)(len - end - 1)); b->bv_ga.ga_len -= end - idx + 1; } } diff --git a/src/version.c b/src/version.c index 83d7e5725..12a51c912 100644 --- a/src/version.c +++ b/src/version.c @@ -751,6 +751,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 2779, +/**/ 2778, /**/ 2777, |