diff options
author | Bram Moolenaar <Bram@vim.org> | 2017-04-10 22:22:42 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2017-04-10 22:22:42 +0200 |
commit | 478af67dd6a9adc456464c3736bda328ae3a28cb (patch) | |
tree | cba8ed52ec81c2416324d194c642179536f3e802 | |
parent | 451a4a1cb7797e5d9b9fd625671cb5c652e7da00 (diff) | |
download | vim-git-478af67dd6a9adc456464c3736bda328ae3a28cb.tar.gz |
patch 8.0.0561: undefined behavior when using backslash after empty linev8.0.0561
Problem: Undefined behavior when using backslash after empty line.
Solution: Check for an empty line. (Dominique Pelle, closes #1631)
-rw-r--r-- | src/misc2.c | 2 | ||||
-rw-r--r-- | src/testdir/test_vimscript.vim | 11 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 14 insertions, 1 deletions
diff --git a/src/misc2.c b/src/misc2.c index 2f9fed57a..fa06e4740 100644 --- a/src/misc2.c +++ b/src/misc2.c @@ -2129,7 +2129,7 @@ ga_concat(garray_T *gap, char_u *s) { int len; - if (s == NULL) + if (s == NULL || *s == NUL) return; len = (int)STRLEN(s); if (ga_grow(gap, len) == OK) diff --git a/src/testdir/test_vimscript.vim b/src/testdir/test_vimscript.vim index a299581e8..ce28e82c6 100644 --- a/src/testdir/test_vimscript.vim +++ b/src/testdir/test_vimscript.vim @@ -1310,6 +1310,17 @@ func Test_script_lines() endfunc "------------------------------------------------------------------------------- +" Test 96: line continuation {{{1 +" +" Undefined behavior was detected by ubsan with line continuation +" after an empty line. +"------------------------------------------------------------------------------- +func Test_script_emty_line_continuation() + + \ +endfunc + +"------------------------------------------------------------------------------- " Modelines {{{1 " vim: ts=8 sw=4 tw=80 fdm=marker " vim: fdt=substitute(substitute(foldtext(),\ '\\%(^+--\\)\\@<=\\(\\s*\\)\\(.\\{-}\\)\:\ \\%(\"\ \\)\\=\\(Test\ \\d*\\)\:\\s*',\ '\\3\ (\\2)\:\ \\1',\ \"\"),\ '\\(Test\\s*\\)\\(\\d\\)\\D\\@=',\ '\\1\ \\2',\ "") diff --git a/src/version.c b/src/version.c index 325be558f..91ef1f359 100644 --- a/src/version.c +++ b/src/version.c @@ -765,6 +765,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 561, +/**/ 560, /**/ 559, |