diff options
| author | Jurica Bradaric <jbradaric@gmail.com> | 2016-08-27 17:35:54 +0200 | 
|---|---|---|
| committer | Jurica Bradaric <jbradaric@gmail.com> | 2016-10-07 17:07:16 +0200 | 
| commit | d8079e5ab7c9cb029db35f725333ea95d515e337 (patch) | |
| tree | 8b0dc4646bf28b183ee8986726f3611e006e9e78 /src/nvim/eval.c | |
| parent | b6300742d2063373b1bf1adee03a97dd3190f069 (diff) | |
| download | rneovim-d8079e5ab7c9cb029db35f725333ea95d515e337.tar.gz rneovim-d8079e5ab7c9cb029db35f725333ea95d515e337.tar.bz2 rneovim-d8079e5ab7c9cb029db35f725333ea95d515e337.zip | |
vim-patch:7.4.1893
Problem:    Cannot easily get the window ID for a buffer.
Solution:   Add bufwinid().
https://github.com/vim/vim/commit/b3619a90eae2702553ff9494ecc4c9b20c13c224
Diffstat (limited to 'src/nvim/eval.c')
| -rw-r--r-- | src/nvim/eval.c | 29 | 
1 files changed, 19 insertions, 10 deletions
| diff --git a/src/nvim/eval.c b/src/nvim/eval.c index 0b1fd6670e..2c09dcd420 100644 --- a/src/nvim/eval.c +++ b/src/nvim/eval.c @@ -6709,7 +6709,6 @@ static int get_env_tv(char_u **arg, typval_T *rettv, int evaluate)  # include "funcs.generated.h"  #endif -  /*   * Function given to ExpandGeneric() to obtain the list of internal   * or user defined function names. @@ -7712,26 +7711,36 @@ static void f_bufnr(typval_T *argvars, typval_T *rettv, FunPtr fptr)      rettv->vval.v_number = -1;  } -/* - * "bufwinnr(nr)" function - */ -static void f_bufwinnr(typval_T *argvars, typval_T *rettv, FunPtr fptr) +static void buf_win_common(typval_T *argvars, typval_T *rettv, bool get_nr)  { -  (void)get_tv_number(&argvars[0]);         /* issue errmsg if type error */ -  ++emsg_off; +  (void)get_tv_number(&argvars[0]);  // issue errmsg if type error +  emsg_off++;    buf_T *buf = get_buf_tv(&argvars[0], TRUE);    int winnr = 0; +  int winid;    bool found_buf = false;    FOR_ALL_WINDOWS_IN_TAB(wp, curtab) { -    ++winnr; +    winnr++;      if (wp->w_buffer == buf) {        found_buf = true; +      winid = wp->handle;        break;      }    } -  rettv->vval.v_number = (found_buf ? winnr : -1); -  --emsg_off; +  rettv->vval.v_number = (found_buf ? (get_nr ? winnr : winid) : -1); +  emsg_off--; +} + +/// "bufwinid(nr)" function +static void f_bufwinid(typval_T *argvars, typval_T *rettv, FunPtr fptr) { +  buf_win_common(argvars, rettv, false); +} + +/// "bufwinnr(nr)" function +static void f_bufwinnr(typval_T *argvars, typval_T *rettv, FunPtr fptr) +{ +  buf_win_common(argvars, rettv, true);  }  /* | 
