Mercurial > vim
view src/testdir/test_source_utf8.vim @ 10720:44a1661f4cfa v8.0.0250
patch 8.0.0250: virtcol() does not work well for multi-byte characters
commit https://github.com/vim/vim/commit/0c0590d9827cb07a33c1552cb3558b94bddcb4dc
Author: Bram Moolenaar <Bram@vim.org>
Date: Sat Jan 28 13:48:10 2017 +0100
patch 8.0.0250: virtcol() does not work well for multi-byte characters
Problem: When virtcol() gets a column that is not the first byte of a
multi-byte character the result is unpredictable. (Christian
Ludwig)
Solution: Correct the column to the first byte of a multi-byte character.
Change the utf-8 test to new style.
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Sat, 28 Jan 2017 14:00:04 +0100 |
parents | bff8a09016a5 |
children | aa658b33f25a |
line wrap: on
line source
" Test the :source! command if !has('multi_byte') finish endif func Test_source_utf8() " check that sourcing a script with 0x80 as second byte works new call setline(1, [':%s/àx/--à1234--/g', ':%s/Àx/--À1234--/g']) write! Xscript bwipe! new call setline(1, [' àx ', ' Àx ']) source! Xscript | echo call assert_equal(' --à1234-- ', getline(1)) call assert_equal(' --À1234-- ', getline(2)) bwipe! call delete('Xscript') endfunc func Test_source_latin() " check that sourcing a latin1 script with a 0xc0 byte works new call setline(1, ["call feedkeys('r')", "call feedkeys('\xc0', 'xt')"]) write! Xscript bwipe! new call setline(1, ['xxx']) source Xscript call assert_equal("\u00c0xx", getline(1)) bwipe! call delete('Xscript') endfunc