|
|
3ef2ca |
To: vim_dev@googlegroups.com
|
|
|
3ef2ca |
Subject: Patch 7.4.434
|
|
|
3ef2ca |
Fcc: outbox
|
|
|
3ef2ca |
From: Bram Moolenaar <Bram@moolenaar.net>
|
|
|
3ef2ca |
Mime-Version: 1.0
|
|
|
3ef2ca |
Content-Type: text/plain; charset=UTF-8
|
|
|
3ef2ca |
Content-Transfer-Encoding: 8bit
|
|
|
3ef2ca |
------------
|
|
|
3ef2ca |
|
|
|
3ef2ca |
Patch 7.4.434
|
|
|
3ef2ca |
Problem: gettabvar() is not consistent with getwinvar() and getbufvar().
|
|
|
3ef2ca |
Solution: Return a dict with all variables when the varname is empty.
|
|
|
3ef2ca |
(Yasuhiro Matsumoto)
|
|
|
3ef2ca |
Files: src/eval.c, runtime/doc/eval.txt, src/testdir/test91.in,
|
|
|
3ef2ca |
src/testdir/test91.ok
|
|
|
3ef2ca |
|
|
|
3ef2ca |
|
|
|
3ef2ca |
*** ../vim-7.4.433/src/eval.c 2014-08-29 15:53:43.706453155 +0200
|
|
|
3ef2ca |
--- src/eval.c 2014-09-09 16:03:34.372530448 +0200
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 12071,12077 ****
|
|
|
3ef2ca |
typval_T *argvars;
|
|
|
3ef2ca |
typval_T *rettv;
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
! tabpage_T *tp;
|
|
|
3ef2ca |
dictitem_T *v;
|
|
|
3ef2ca |
char_u *varname;
|
|
|
3ef2ca |
int done = FALSE;
|
|
|
3ef2ca |
--- 12071,12078 ----
|
|
|
3ef2ca |
typval_T *argvars;
|
|
|
3ef2ca |
typval_T *rettv;
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
! win_T *win, *oldcurwin;
|
|
|
3ef2ca |
! tabpage_T *tp, *oldtabpage;
|
|
|
3ef2ca |
dictitem_T *v;
|
|
|
3ef2ca |
char_u *varname;
|
|
|
3ef2ca |
int done = FALSE;
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 12083,12095 ****
|
|
|
3ef2ca |
tp = find_tabpage((int)get_tv_number_chk(&argvars[0], NULL));
|
|
|
3ef2ca |
if (tp != NULL && varname != NULL)
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
/* look up the variable */
|
|
|
3ef2ca |
! v = find_var_in_ht(&tp->tp_vars->dv_hashtab, 0, varname, FALSE);
|
|
|
3ef2ca |
if (v != NULL)
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
copy_tv(&v->di_tv, rettv);
|
|
|
3ef2ca |
done = TRUE;
|
|
|
3ef2ca |
}
|
|
|
3ef2ca |
}
|
|
|
3ef2ca |
|
|
|
3ef2ca |
if (!done && argvars[2].v_type != VAR_UNKNOWN)
|
|
|
3ef2ca |
--- 12084,12104 ----
|
|
|
3ef2ca |
tp = find_tabpage((int)get_tv_number_chk(&argvars[0], NULL));
|
|
|
3ef2ca |
if (tp != NULL && varname != NULL)
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
+ /* Set curwin to be our win, temporarily. Also set the tabpage,
|
|
|
3ef2ca |
+ * otherwise the window is not valid. */
|
|
|
3ef2ca |
+ switch_win(&oldcurwin, &oldtabpage, win, tp, TRUE);
|
|
|
3ef2ca |
+
|
|
|
3ef2ca |
/* look up the variable */
|
|
|
3ef2ca |
! /* Let gettabvar({nr}, "") return the "t:" dictionary. */
|
|
|
3ef2ca |
! v = find_var_in_ht(&tp->tp_vars->dv_hashtab, 't', varname, FALSE);
|
|
|
3ef2ca |
if (v != NULL)
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
copy_tv(&v->di_tv, rettv);
|
|
|
3ef2ca |
done = TRUE;
|
|
|
3ef2ca |
}
|
|
|
3ef2ca |
+
|
|
|
3ef2ca |
+ /* restore previous notion of curwin */
|
|
|
3ef2ca |
+ restore_win(oldcurwin, oldtabpage, TRUE);
|
|
|
3ef2ca |
}
|
|
|
3ef2ca |
|
|
|
3ef2ca |
if (!done && argvars[2].v_type != VAR_UNKNOWN)
|
|
|
3ef2ca |
*** ../vim-7.4.433/runtime/doc/eval.txt 2014-08-29 15:53:43.714453155 +0200
|
|
|
3ef2ca |
--- runtime/doc/eval.txt 2014-09-09 16:00:31.776530049 +0200
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 3535,3540 ****
|
|
|
3ef2ca |
--- 3576,3583 ----
|
|
|
3ef2ca |
Get the value of a tab-local variable {varname} in tab page
|
|
|
3ef2ca |
{tabnr}. |t:var|
|
|
|
3ef2ca |
Tabs are numbered starting with one.
|
|
|
3ef2ca |
+ When {varname} is empty a dictionary with all tab-local
|
|
|
3ef2ca |
+ variables is returned.
|
|
|
3ef2ca |
Note that the name without "t:" must be used.
|
|
|
3ef2ca |
When the tab or variable doesn't exist {def} or an empty
|
|
|
3ef2ca |
string is returned, there is no error message.
|
|
|
3ef2ca |
*** ../vim-7.4.433/src/testdir/test91.in 2013-07-24 14:53:47.000000000 +0200
|
|
|
3ef2ca |
--- src/testdir/test91.in 2014-09-09 16:08:40.116531116 +0200
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 55,60 ****
|
|
|
3ef2ca |
--- 55,61 ----
|
|
|
3ef2ca |
:tabnew
|
|
|
3ef2ca |
:tabnew
|
|
|
3ef2ca |
:let t:var_list = [1, 2, 3]
|
|
|
3ef2ca |
+ :let t:other = 777
|
|
|
3ef2ca |
:let def_list = [4, 5, 6, 7]
|
|
|
3ef2ca |
:tabrewind
|
|
|
3ef2ca |
:$put =string(gettabvar(3, 'var_list'))
|
|
|
3ef2ca |
*** ../vim-7.4.433/src/testdir/test91.ok 2013-07-24 14:52:47.000000000 +0200
|
|
|
3ef2ca |
--- src/testdir/test91.ok 2014-09-09 16:09:27.624531220 +0200
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 26,33 ****
|
|
|
3ef2ca |
0
|
|
|
3ef2ca |
[1, 2, 3]
|
|
|
3ef2ca |
[1, 2, 3]
|
|
|
3ef2ca |
! ''
|
|
|
3ef2ca |
! [4, 5, 6, 7]
|
|
|
3ef2ca |
[4, 5, 6, 7]
|
|
|
3ef2ca |
''
|
|
|
3ef2ca |
[4, 5, 6, 7]
|
|
|
3ef2ca |
--- 26,33 ----
|
|
|
3ef2ca |
0
|
|
|
3ef2ca |
[1, 2, 3]
|
|
|
3ef2ca |
[1, 2, 3]
|
|
|
3ef2ca |
! {'var_list': [1, 2, 3], 'other': 777}
|
|
|
3ef2ca |
! {'var_list': [1, 2, 3], 'other': 777}
|
|
|
3ef2ca |
[4, 5, 6, 7]
|
|
|
3ef2ca |
''
|
|
|
3ef2ca |
[4, 5, 6, 7]
|
|
|
3ef2ca |
*** ../vim-7.4.433/src/version.c 2014-09-09 13:52:55.028513324 +0200
|
|
|
3ef2ca |
--- src/version.c 2014-09-09 16:09:17.824531199 +0200
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 743,744 ****
|
|
|
3ef2ca |
--- 743,746 ----
|
|
|
3ef2ca |
{ /* Add new patch number below this line */
|
|
|
3ef2ca |
+ /**/
|
|
|
3ef2ca |
+ 434,
|
|
|
3ef2ca |
/**/
|
|
|
3ef2ca |
|
|
|
3ef2ca |
--
|
|
|
3ef2ca |
hundred-and-one symptoms of being an internet addict:
|
|
|
3ef2ca |
108. While reading a magazine, you look for the Zoom icon for a better
|
|
|
3ef2ca |
look at a photograph.
|
|
|
3ef2ca |
|
|
|
3ef2ca |
/// Bram Moolenaar -- Bram@Moolenaar.net -- http://www.Moolenaar.net \\\
|
|
|
3ef2ca |
/// sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\
|
|
|
3ef2ca |
\\\ an exciting new programming language -- http://www.Zimbu.org ///
|
|
|
3ef2ca |
\\\ help me help AIDS victims -- http://ICCF-Holland.org ///
|