diff options
| -rw-r--r-- | src/nvim/fileio.c | 60 | ||||
| -rw-r--r-- | src/nvim/testdir/test_fileformat.vim | 16 | ||||
| -rw-r--r-- | src/nvim/version.c | 4 | 
3 files changed, 51 insertions, 29 deletions
| diff --git a/src/nvim/fileio.c b/src/nvim/fileio.c index feb16f44d4..a7676e88f0 100644 --- a/src/nvim/fileio.c +++ b/src/nvim/fileio.c @@ -302,12 +302,9 @@ readfile (    linenr_T skip_count = 0;    linenr_T read_count = 0;    int msg_save = msg_scroll; -  linenr_T read_no_eol_lnum = 0;        /* non-zero lnum when last line of -                                        * last read was missing the eol */ -  int try_mac = (vim_strchr(p_ffs, 'm') != NULL); -  int try_dos = (vim_strchr(p_ffs, 'd') != NULL); -  int try_unix = (vim_strchr(p_ffs, 'x') != NULL); -  int file_rewind = FALSE; +  linenr_T read_no_eol_lnum = 0;        // non-zero lnum when last line of +                                        // last read was missing the eol +  int file_rewind = false;    int can_retry;    linenr_T conv_error = 0;              /* line nr with conversion error */    linenr_T illegal_byte = 0;            /* line nr with illegal byte */ @@ -639,37 +636,46 @@ readfile (    curbuf->b_op_start.lnum = ((from == 0) ? 1 : from);    curbuf->b_op_start.col = 0; +  int try_mac = (vim_strchr(p_ffs, 'm') != NULL); +  int try_dos = (vim_strchr(p_ffs, 'd') != NULL); +  int try_unix = (vim_strchr(p_ffs, 'x') != NULL); +    if (!read_buffer) {      int m = msg_scroll;      int n = msg_scrolled; -    /* -     * The file must be closed again, the autocommands may want to change -     * the file before reading it. -     */ -    if (!read_stdin) -      close(fd);                /* ignore errors */ +    // The file must be closed again, the autocommands may want to change +    // the file before reading it. +    if (!read_stdin) { +      close(fd);                // ignore errors +    } -    /* -     * The output from the autocommands should not overwrite anything and -     * should not be overwritten: Set msg_scroll, restore its value if no -     * output was done. -     */ -    msg_scroll = TRUE; -    if (filtering) +    // The output from the autocommands should not overwrite anything and +    // should not be overwritten: Set msg_scroll, restore its value if no +    // output was done. +    msg_scroll = true; +    if (filtering) {        apply_autocmds_exarg(EVENT_FILTERREADPRE, NULL, sfname, -          FALSE, curbuf, eap); -    else if (read_stdin) +                           false, curbuf, eap); +    } else if (read_stdin) {        apply_autocmds_exarg(EVENT_STDINREADPRE, NULL, sfname, -          FALSE, curbuf, eap); -    else if (newfile) +                           false, curbuf, eap); +    } else if (newfile) {        apply_autocmds_exarg(EVENT_BUFREADPRE, NULL, sfname, -          FALSE, curbuf, eap); -    else +                           false, curbuf, eap); +    } else {        apply_autocmds_exarg(EVENT_FILEREADPRE, sfname, sfname, -          FALSE, NULL, eap); -    if (msg_scrolled == n) +                           false, NULL, eap); +    } + +    // autocommands may have changed it +    try_mac = (vim_strchr(p_ffs, 'm') != NULL); +    try_dos = (vim_strchr(p_ffs, 'd') != NULL); +    try_unix = (vim_strchr(p_ffs, 'x') != NULL); + +    if (msg_scrolled == n) {        msg_scroll = m; +    }      if (aborting()) {       /* autocmds may abort script processing */        --no_wait_return; diff --git a/src/nvim/testdir/test_fileformat.vim b/src/nvim/testdir/test_fileformat.vim index 584f20cdfc..de505d3bd0 100644 --- a/src/nvim/testdir/test_fileformat.vim +++ b/src/nvim/testdir/test_fileformat.vim @@ -15,3 +15,19 @@ func Test_fileformat_after_bw()    call assert_equal(test_fileformats, &fileformat)    set fileformats&  endfunc + +func Test_fileformat_autocommand() +  let filecnt = ["\<CR>", "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 +  new Xfile +  call assert_equal('dos', &l:ff) +  call assert_equal('dos', &ffs) + +  " cleanup +  call delete('Xfile') +  let &ffs = ffs +  au! BufReadPre Xfile +  bw! +endfunc diff --git a/src/nvim/version.c b/src/nvim/version.c index 8c9bea9a9b..5accf8f1d6 100644 --- a/src/nvim/version.c +++ b/src/nvim/version.c @@ -878,9 +878,9 @@ static const int included_patches[] = {    229,    // 228,    // 227, -  // 226, +  226,    // 225, -  // 224, +  224,    223,    // 222,    // 221 NA | 
