diff options
author | Bram Moolenaar <Bram@vim.org> | 2017-12-22 21:06:56 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2017-12-22 21:06:56 +0100 |
commit | e6640ad44e2186bd3642b972115496d347cd1fdd (patch) | |
tree | 647370d0a60e9adbdd4acb9ef0b6235be513d1e1 /src/testdir/test_functions.vim | |
parent | 3c09722600e3218905b5d4a7b635a9e6560f87b3 (diff) | |
download | vim-git-e6640ad44e2186bd3642b972115496d347cd1fdd.tar.gz |
patch 8.0.1421: accessing invalid memory with overlong byte sequencev8.0.1421
Problem: Accessing invalid memory with overlong byte sequence.
Solution: Check for NUL character. (test by Dominique Pelle, closes #2485)
Diffstat (limited to 'src/testdir/test_functions.vim')
-rw-r--r-- | src/testdir/test_functions.vim | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/src/testdir/test_functions.vim b/src/testdir/test_functions.vim index 20e4280c1..ffc3bc378 100644 --- a/src/testdir/test_functions.vim +++ b/src/testdir/test_functions.vim @@ -268,6 +268,11 @@ func Test_tolower() " Ⱥ (U+023A) and Ⱦ (U+023E) are the *only* code points to increase " in length (2 to 3 bytes) when lowercased. So let's test them. call assert_equal("ⱥ ⱦ", tolower("Ⱥ Ⱦ")) + + " This call to tolower with invalid utf8 sequence used to cause access to + " invalid memory. + call tolower("\xC0\x80\xC0") + call tolower("123\xC0\x80\xC0") endfunc func Test_toupper() @@ -338,6 +343,11 @@ func Test_toupper() call assert_equal("ZŹŻŽƵẐẔ", toupper("ZŹŻŽƵẐẔ")) call assert_equal("Ⱥ Ⱦ", toupper("ⱥ ⱦ")) + + " This call to toupper with invalid utf8 sequence used to cause access to + " invalid memory. + call toupper("\xC0\x80\xC0") + call toupper("123\xC0\x80\xC0") endfunc " Tests for the mode() function |