summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2017-01-24 15:46:48 +0100
committerBram Moolenaar <Bram@vim.org>2017-01-24 15:46:48 +0100
commit2aa5f696b91a51f29873e340de4bdc182e1e8dd4 (patch)
tree1249e92e01a82836352dcf6be011b0fcdabd7d40
parent1695f99d08076d77ed3015f1edf09a668a4d449a (diff)
downloadvim-git-2aa5f696b91a51f29873e340de4bdc182e1e8dd4.tar.gz
patch 8.0.0227: crash with ff=dos when first line in file has no CRv8.0.0227
Problem: Crash when 'fileformat' is forced to "dos" and the first line in the file is empty and does not have a CR character. Solution: Don't check for CR before the start of the buffer.
-rw-r--r--src/fileio.c3
-rw-r--r--src/testdir/test_fileformat.vim2
-rw-r--r--src/version.c2
3 files changed, 5 insertions, 2 deletions
diff --git a/src/fileio.c b/src/fileio.c
index 39e356f88..9380953d2 100644
--- a/src/fileio.c
+++ b/src/fileio.c
@@ -2251,8 +2251,9 @@ rewind_retry:
len = (colnr_T)(ptr - line_start + 1);
if (fileformat == EOL_DOS)
{
- if (ptr[-1] == CAR) /* remove CR */
+ if (ptr > line_start && ptr[-1] == CAR)
{
+ /* remove CR before NL */
ptr[-1] = NUL;
--len;
}
diff --git a/src/testdir/test_fileformat.vim b/src/testdir/test_fileformat.vim
index de505d3bd..8dc25f62b 100644
--- a/src/testdir/test_fileformat.vim
+++ b/src/testdir/test_fileformat.vim
@@ -17,7 +17,7 @@ func Test_fileformat_after_bw()
endfunc
func Test_fileformat_autocommand()
- let filecnt = ["\<CR>", "foobar\<CR>", "eins\<CR>", "\<CR>", "zwei\<CR>", "drei", "vier", "fünf", ""]
+ let filecnt = ["", "foobar\<CR>", "eins\<CR>", "\<CR>", "zwei\<CR>", "drei", "vier", "fünf", ""]
let ffs = &ffs
call writefile(filecnt, 'Xfile', 'b')
au BufReadPre Xfile set ffs=dos ff=dos
diff --git a/src/version.c b/src/version.c
index 7087f6424..84dde7353 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 */
/**/
+ 227,
+/**/
226,
/**/
225,