aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/strings.c
diff options
context:
space:
mode:
authorJurica Bradaric <jbradaric@gmail.com>2016-01-23 14:32:52 +0100
committerJurica Bradaric <jbradaric@gmail.com>2016-01-24 09:15:30 +0100
commitee564701579e66a16245328d9e574dcb0752d517 (patch)
tree19d519402b3eff5a7498f7f4e46f367db1288e47 /src/nvim/strings.c
parent4172ce4eb078fe63cf3696dd10f9bdf47cd70eb1 (diff)
downloadrneovim-ee564701579e66a16245328d9e574dcb0752d517.tar.gz
rneovim-ee564701579e66a16245328d9e574dcb0752d517.tar.bz2
rneovim-ee564701579e66a16245328d9e574dcb0752d517.zip
vim-patch:7.4.704
Problem: Searching for a character matches an illegal byte and causes invalid memory access. (Dominique Pelle) Solution: Do not match an invalid byte when search for a character in a string. Fix equivalence classes using negative numbers, which result in illegal bytes. https://github.com/vim/vim/commit/d82a2a990bc329754e1b61c5af669c76ac202497
Diffstat (limited to 'src/nvim/strings.c')
-rw-r--r--src/nvim/strings.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/src/nvim/strings.c b/src/nvim/strings.c
index fe91141375..30a9052a1e 100644
--- a/src/nvim/strings.c
+++ b/src/nvim/strings.c
@@ -425,9 +425,13 @@ char_u *vim_strchr(const char_u *string, int c)
const char_u *p = string;
if (enc_utf8 && c >= 0x80) {
while (*p != NUL) {
- if (utf_ptr2char(p) == c)
+ int l = (*mb_ptr2len)(p);
+
+ // Avoid matching an illegal byte here.
+ if (utf_ptr2char(p) == c && l > 1) {
return (char_u *) p;
- p += (*mb_ptr2len)(p);
+ }
+ p += l;
}
return NULL;
}