diff options
| author | Jurica Bradaric <jbradaric@gmail.com> | 2016-08-27 17:57:05 +0200 | 
|---|---|---|
| committer | Jurica Bradaric <jbradaric@gmail.com> | 2016-10-07 17:07:16 +0200 | 
| commit | 50bd8297e67814b3ddbf0f274314fd2d321f63b6 (patch) | |
| tree | 35629b612e1af37562bbb4f1059add230c1f471b /src | |
| parent | d8079e5ab7c9cb029db35f725333ea95d515e337 (diff) | |
| download | rneovim-50bd8297e67814b3ddbf0f274314fd2d321f63b6.tar.gz rneovim-50bd8297e67814b3ddbf0f274314fd2d321f63b6.tar.bz2 rneovim-50bd8297e67814b3ddbf0f274314fd2d321f63b6.zip | |
vim-patch:7.4.1895
Problem:    Cannot use a window ID where a window number is expected.
Solution:   Add LOWEST_WIN_ID, so that the window ID can be used where a
            number is expected.
https://github.com/vim/vim/commit/888ccac8902cee186fbd47e971881f6d9b19c068
Diffstat (limited to 'src')
| -rw-r--r-- | src/nvim/eval.c | 6 | ||||
| -rw-r--r-- | src/nvim/testdir/test_window_id.vim | 15 | ||||
| -rw-r--r-- | src/nvim/version.c | 2 | ||||
| -rw-r--r-- | src/nvim/vim.h | 3 | ||||
| -rw-r--r-- | src/nvim/window.c | 2 | 
5 files changed, 25 insertions, 3 deletions
| diff --git a/src/nvim/eval.c b/src/nvim/eval.c index 2c09dcd420..f077458c9b 100644 --- a/src/nvim/eval.c +++ b/src/nvim/eval.c @@ -10268,7 +10268,11 @@ find_win_by_nr (    }    FOR_ALL_WINDOWS_IN_TAB(wp, tp) { -    if (--nr <= 0) { +    if (nr >= LOWEST_WIN_ID) { +      if (wp->handle == nr) { +        return wp; +      } +    } else if (--nr <= 0) {        return wp;      }    } diff --git a/src/nvim/testdir/test_window_id.vim b/src/nvim/testdir/test_window_id.vim index fa3ebd757e..66656e1d0a 100644 --- a/src/nvim/testdir/test_window_id.vim +++ b/src/nvim/testdir/test_window_id.vim @@ -3,17 +3,22 @@  func Test_win_getid()    edit one    let id1 = win_getid() +  let w:one = 'one'    split two    let id2 = win_getid()    let bufnr2 = bufnr('%') +  let w:two = 'two'    split three    let id3 = win_getid() +  let w:three = 'three'    tabnew    edit four    let id4 = win_getid() +  let w:four = 'four'    split five    let id5 = win_getid()    let bufnr5 = bufnr('%') +  let w:five = 'five'    tabnext    wincmd w @@ -28,6 +33,9 @@ func Test_win_getid()    call assert_equal("three", expand("%"))    call assert_equal(id3, win_getid())    let nr3 = winnr() +  call assert_equal('one', getwinvar(id1, 'one')) +  call assert_equal('two', getwinvar(id2, 'two')) +  call assert_equal('three', getwinvar(id3, 'three'))    tabnext    call assert_equal("five", expand("%"))    call assert_equal(id5, win_getid()) @@ -36,7 +44,14 @@ func Test_win_getid()    call assert_equal("four", expand("%"))    call assert_equal(id4, win_getid())    let nr4 = winnr() +  call assert_equal('four', getwinvar(id4, 'four')) +  call assert_equal('five', getwinvar(id5, 'five')) +  call settabwinvar(1, id2, 'two', '2') +  call setwinvar(id4, 'four', '4')    tabnext +  call assert_equal('4', gettabwinvar(2, id4, 'four')) +  call assert_equal('five', gettabwinvar(2, id5, 'five')) +  call assert_equal('2', getwinvar(id2, 'two'))    exe nr1 . "wincmd w"    call assert_equal(id1, win_getid()) diff --git a/src/nvim/version.c b/src/nvim/version.c index c46aaf28b5..f56942ac43 100644 --- a/src/nvim/version.c +++ b/src/nvim/version.c @@ -546,7 +546,7 @@ static int included_patches[] = {    1898,    // 1897,    1896, -  // 1895, +  1895,    // 1894 NA    1893,    // 1892 NA diff --git a/src/nvim/vim.h b/src/nvim/vim.h index 09e9e850a7..6bbd9b58ef 100644 --- a/src/nvim/vim.h +++ b/src/nvim/vim.h @@ -316,4 +316,7 @@ enum {  #define DIP_OPT 0x10    // also use "opt" directory in 'packpath'  #define DIP_NORTP 0x20  // do not use 'runtimepath' +// Lowest number used for window ID. Cannot have this many windows per tab. +#define LOWEST_WIN_ID 1000 +  #endif /* NVIM_VIM_H */ diff --git a/src/nvim/window.c b/src/nvim/window.c index e9a66ad907..66f1049b5e 100644 --- a/src/nvim/window.c +++ b/src/nvim/window.c @@ -3694,7 +3694,7 @@ win_T *buf_jump_open_tab(buf_T *buf)   */  static win_T *win_alloc(win_T *after, int hidden)  { -  static int last_win_id = 0; +  static int last_win_id = LOWEST_WIN_ID - 1;    // allocate window structure and linesizes arrays    win_T *new_wp = xcalloc(1, sizeof(win_T)); | 
