1
0
forked from aniani/vim

patch 8.1.0333: :mkview does not restore cursor properly after "$"

Problem:    :mkview does not restore cursor properly after "$". (Dominique
            Pelle)
Solution:   Position the cursor with "normal! $".
This commit is contained in:
Bram Moolenaar
2018-08-29 21:42:42 +02:00
parent a449a7c6b9
commit 92c1b69641
3 changed files with 27 additions and 14 deletions

View File

@@ -11706,6 +11706,18 @@ ses_do_win(win_T *wp)
return TRUE; return TRUE;
} }
static int
put_view_curpos(FILE *fd, win_T *wp, char *spaces)
{
int r;
if (wp->w_curswant == MAXCOL)
r = fprintf(fd, "%snormal! $", spaces);
else
r = fprintf(fd, "%snormal! 0%d|", spaces, wp->w_virtcol + 1);
return r < 0 || put_eol(fd) == FAIL ? FALSE : OK;
}
/* /*
* Write commands to "fd" to restore the view of a window. * Write commands to "fd" to restore the view of a window.
* Caller must make sure 'scrolloff' is zero. * Caller must make sure 'scrolloff' is zero.
@@ -11897,19 +11909,14 @@ put_view(
(long)wp->w_virtcol + 1) < 0 (long)wp->w_virtcol + 1) < 0
|| put_eol(fd) == FAIL || put_eol(fd) == FAIL
|| put_line(fd, "else") == FAIL || put_line(fd, "else") == FAIL
|| fprintf(fd, " normal! 0%d|", wp->w_virtcol + 1) < 0 || put_view_curpos(fd, wp, " ") == FAIL
|| put_eol(fd) == FAIL
|| put_line(fd, "endif") == FAIL) || put_line(fd, "endif") == FAIL)
return FAIL; return FAIL;
} }
else else if (put_view_curpos(fd, wp, "") == FAIL)
{
if (fprintf(fd, "normal! 0%d|", wp->w_virtcol + 1) < 0
|| put_eol(fd) == FAIL)
return FAIL; return FAIL;
} }
} }
}
/* /*
* Local directory, if the current flag is not view options or the "curdir" * Local directory, if the current flag is not view options or the "curdir"

View File

@@ -22,7 +22,8 @@ func Test_mksession()
\ 'two tabs in one line', \ 'two tabs in one line',
\ 'one <20> multibyteCharacter', \ 'one <20> multibyteCharacter',
\ 'a<> <20> two multiByte characters', \ 'a<> <20> two multiByte characters',
\ 'A<><41><EFBFBD> three mulTibyte characters' \ 'A<><41><EFBFBD> three mulTibyte characters',
\ 'short line',
\ ]) \ ])
let tmpfile = 'Xtemp' let tmpfile = 'Xtemp'
exec 'w! ' . tmpfile exec 'w! ' . tmpfile
@@ -44,6 +45,8 @@ func Test_mksession()
norm! j16| norm! j16|
split split
norm! j16| norm! j16|
split
norm! j$
wincmd l wincmd l
set nowrap set nowrap
@@ -66,7 +69,7 @@ func Test_mksession()
split split
call wincol() call wincol()
mksession! Xtest_mks.out mksession! Xtest_mks.out
let li = filter(readfile('Xtest_mks.out'), 'v:val =~# "\\(^ *normal! 0\\|^ *exe ''normal!\\)"') let li = filter(readfile('Xtest_mks.out'), 'v:val =~# "\\(^ *normal! [0$]\\|^ *exe ''normal!\\)"')
let expected = [ let expected = [
\ 'normal! 016|', \ 'normal! 016|',
\ 'normal! 016|', \ 'normal! 016|',
@@ -76,6 +79,7 @@ func Test_mksession()
\ 'normal! 016|', \ 'normal! 016|',
\ 'normal! 016|', \ 'normal! 016|',
\ 'normal! 016|', \ 'normal! 016|',
\ 'normal! $',
\ " exe 'normal! ' . s:c . '|zs' . 16 . '|'", \ " exe 'normal! ' . s:c . '|zs' . 16 . '|'",
\ " normal! 016|", \ " normal! 016|",
\ " exe 'normal! ' . s:c . '|zs' . 16 . '|'", \ " exe 'normal! ' . s:c . '|zs' . 16 . '|'",
@@ -317,7 +321,7 @@ func Test_mkview_file()
help :mkview help :mkview
set number set number
norm! V}zf norm! V}zf
let pos = getpos('.') let pos = getcurpos()
let linefoldclosed1 = foldclosed('.') let linefoldclosed1 = foldclosed('.')
mkview! Xview mkview! Xview
set nonumber set nonumber
@@ -329,7 +333,7 @@ func Test_mkview_file()
source Xview source Xview
call assert_equal(1, &number) call assert_equal(1, &number)
call assert_match('\*:mkview\*$', getline('.')) call assert_match('\*:mkview\*$', getline('.'))
call assert_equal(pos, getpos('.')) call assert_equal(pos, getcurpos())
call assert_equal(linefoldclosed1, foldclosed('.')) call assert_equal(linefoldclosed1, foldclosed('.'))
" Creating a view again with the same file name should fail (file " Creating a view again with the same file name should fail (file
@@ -352,7 +356,7 @@ func Test_mkview_loadview_with_viewdir()
help :mkview help :mkview
set number set number
norm! V}zf norm! V}zf
let pos = getpos('.') let pos = getcurpos()
let linefoldclosed1 = foldclosed('.') let linefoldclosed1 = foldclosed('.')
mkview 1 mkview 1
set nonumber set nonumber
@@ -369,7 +373,7 @@ func Test_mkview_loadview_with_viewdir()
\ glob('Xviewdir/*')) \ glob('Xviewdir/*'))
call assert_equal(1, &number) call assert_equal(1, &number)
call assert_match('\*:mkview\*$', getline('.')) call assert_match('\*:mkview\*$', getline('.'))
call assert_equal(pos, getpos('.')) call assert_equal(pos, getcurpos())
call assert_equal(linefoldclosed1, foldclosed('.')) call assert_equal(linefoldclosed1, foldclosed('.'))
call delete('Xviewdir', 'rf') call delete('Xviewdir', 'rf')

View File

@@ -794,6 +794,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
333,
/**/ /**/
332, 332,
/**/ /**/