summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorvimboss <devnull@localhost>2007-08-30 09:12:23 +0000
committervimboss <devnull@localhost>2007-08-30 09:12:23 +0000
commit1dced6f8d0701e348fda002063ec7622f4168a95 (patch)
tree6bd11020ab5974fd44f2c480e9b3c2b52753703d
parentb52c884996da4ff2ae02128230313a96aa2a0055 (diff)
downloadvim-1dced6f8d0701e348fda002063ec7622f4168a95.tar.gz
updated for version 7.1-089v7.1.089v7-1-089
-rw-r--r--src/eval.c120
-rw-r--r--src/version.c2
2 files changed, 74 insertions, 48 deletions
diff --git a/src/eval.c b/src/eval.c
index 8b239f3b..419a63b5 100644
--- a/src/eval.c
+++ b/src/eval.c
@@ -369,17 +369,17 @@ static int call_vim_function __ARGS((char_u *func, int argc, char_u **argv, int
static int ex_let_vars __ARGS((char_u *arg, typval_T *tv, int copy, int semicolon, int var_count, char_u *nextchars));
static char_u *skip_var_list __ARGS((char_u *arg, int *var_count, int *semicolon));
static char_u *skip_var_one __ARGS((char_u *arg));
-static void list_hashtable_vars __ARGS((hashtab_T *ht, char_u *prefix, int empty));
-static void list_glob_vars __ARGS((void));
-static void list_buf_vars __ARGS((void));
-static void list_win_vars __ARGS((void));
+static void list_hashtable_vars __ARGS((hashtab_T *ht, char_u *prefix, int empty, int *first));
+static void list_glob_vars __ARGS((int *first));
+static void list_buf_vars __ARGS((int *first));
+static void list_win_vars __ARGS((int *first));
#ifdef FEAT_WINDOWS
-static void list_tab_vars __ARGS((void));
+static void list_tab_vars __ARGS((int *first));
#endif
-static void list_vim_vars __ARGS((void));
-static void list_script_vars __ARGS((void));
-static void list_func_vars __ARGS((void));
-static char_u *list_arg_vars __ARGS((exarg_T *eap, char_u *arg));
+static void list_vim_vars __ARGS((int *first));
+static void list_script_vars __ARGS((int *first));
+static void list_func_vars __ARGS((int *first));
+static char_u *list_arg_vars __ARGS((exarg_T *eap, char_u *arg, int *first));
static char_u *ex_let_one __ARGS((char_u *arg, typval_T *tv, int copy, char_u *endchars, char_u *op));
static int check_changedtick __ARGS((char_u *arg));
static char_u *get_lval __ARGS((char_u *name, typval_T *rettv, lval_T *lp, int unlet, int skip, int quiet, int fne_flags));
@@ -704,8 +704,8 @@ static dictitem_T *find_var_in_ht __ARGS((hashtab_T *ht, char_u *varname, int wr
static hashtab_T *find_var_ht __ARGS((char_u *name, char_u **varname));
static void vars_clear_ext __ARGS((hashtab_T *ht, int free_val));
static void delete_var __ARGS((hashtab_T *ht, hashitem_T *hi));
-static void list_one_var __ARGS((dictitem_T *v, char_u *prefix));
-static void list_one_var_a __ARGS((char_u *prefix, char_u *name, int type, char_u *string));
+static void list_one_var __ARGS((dictitem_T *v, char_u *prefix, int *first));
+static void list_one_var_a __ARGS((char_u *prefix, char_u *name, int type, char_u *string, int *first));
static void set_var __ARGS((char_u *name, typval_T *varp, int copy));
static int var_check_ro __ARGS((int flags, char_u *name));
static int var_check_fixed __ARGS((int flags, char_u *name));
@@ -1699,6 +1699,7 @@ ex_let(eap)
int semicolon = 0;
char_u op[2];
char_u *argend;
+ int first = TRUE;
argend = skip_var_list(arg, &var_count, &semicolon);
if (argend == NULL)
@@ -1715,19 +1716,19 @@ ex_let(eap)
EMSG(_(e_invarg));
else if (!ends_excmd(*arg))
/* ":let var1 var2" */
- arg = list_arg_vars(eap, arg);
+ arg = list_arg_vars(eap, arg, &first);
else if (!eap->skip)
{
/* ":let" */
- list_glob_vars();
- list_buf_vars();
- list_win_vars();
+ list_glob_vars(&first);
+ list_buf_vars(&first);
+ list_win_vars(&first);
#ifdef FEAT_WINDOWS
- list_tab_vars();
+ list_tab_vars(&first);
#endif
- list_script_vars();
- list_func_vars();
- list_vim_vars();
+ list_script_vars(&first);
+ list_func_vars(&first);
+ list_vim_vars(&first);
}
eap->nextcmd = check_nextcmd(arg);
}
@@ -1932,10 +1933,11 @@ skip_var_one(arg)
* If "empty" is TRUE also list NULL strings as empty strings.
*/
static void
-list_hashtable_vars(ht, prefix, empty)
+list_hashtable_vars(ht, prefix, empty, first)
hashtab_T *ht;
char_u *prefix;
int empty;
+ int *first;
{
hashitem_T *hi;
dictitem_T *di;
@@ -1950,7 +1952,7 @@ list_hashtable_vars(ht, prefix, empty)
di = HI2DI(hi);
if (empty || di->di_tv.v_type != VAR_STRING
|| di->di_tv.vval.v_string != NULL)
- list_one_var(di, prefix);
+ list_one_var(di, prefix, first);
}
}
}
@@ -1959,32 +1961,38 @@ list_hashtable_vars(ht, prefix, empty)
* List global variables.
*/
static void
-list_glob_vars()
+list_glob_vars(first)
+ int *first;
{
- list_hashtable_vars(&globvarht, (char_u *)"", TRUE);
+ list_hashtable_vars(&globvarht, (char_u *)"", TRUE, first);
}
/*
* List buffer variables.
*/
static void
-list_buf_vars()
+list_buf_vars(first)
+ int *first;
{
char_u numbuf[NUMBUFLEN];
- list_hashtable_vars(&curbuf->b_vars.dv_hashtab, (char_u *)"b:", TRUE);
+ list_hashtable_vars(&curbuf->b_vars.dv_hashtab, (char_u *)"b:",
+ TRUE, first);
sprintf((char *)numbuf, "%ld", (long)curbuf->b_changedtick);
- list_one_var_a((char_u *)"b:", (char_u *)"changedtick", VAR_NUMBER, numbuf);
+ list_one_var_a((char_u *)"b:", (char_u *)"changedtick", VAR_NUMBER,
+ numbuf, first);
}
/*
* List window variables.
*/
static void
-list_win_vars()
+list_win_vars(first)
+ int *first;
{
- list_hashtable_vars(&curwin->w_vars.dv_hashtab, (char_u *)"w:", TRUE);
+ list_hashtable_vars(&curwin->w_vars.dv_hashtab,
+ (char_u *)"w:", TRUE, first);
}
#ifdef FEAT_WINDOWS
@@ -1992,9 +2000,11 @@ list_win_vars()
* List tab page variables.
*/
static void
-list_tab_vars()
+list_tab_vars(first)
+ int *first;
{
- list_hashtable_vars(&curtab->tp_vars.dv_hashtab, (char_u *)"t:", TRUE);
+ list_hashtable_vars(&curtab->tp_vars.dv_hashtab,
+ (char_u *)"t:", TRUE, first);
}
#endif
@@ -2002,39 +2012,44 @@ list_tab_vars()
* List Vim variables.
*/
static void
-list_vim_vars()
+list_vim_vars(first)
+ int *first;
{
- list_hashtable_vars(&vimvarht, (char_u *)"v:", FALSE);
+ list_hashtable_vars(&vimvarht, (char_u *)"v:", FALSE, first);
}
/*
* List script-local variables, if there is a script.
*/
static void
-list_script_vars()
+list_script_vars(first)
+ int *first;
{
if (current_SID > 0 && current_SID <= ga_scripts.ga_len)
- list_hashtable_vars(&SCRIPT_VARS(current_SID), (char_u *)"s:", FALSE);
+ list_hashtable_vars(&SCRIPT_VARS(current_SID),
+ (char_u *)"s:", FALSE, first);
}
/*
* List function variables, if there is a function.
*/
static void
-list_func_vars()
+list_func_vars(first)
+ int *first;
{
if (current_funccal != NULL)
list_hashtable_vars(&current_funccal->l_vars.dv_hashtab,
- (char_u *)"l:", FALSE);
+ (char_u *)"l:", FALSE, first);
}
/*
* List variables in "arg".
*/
static char_u *
-list_arg_vars(eap, arg)
+list_arg_vars(eap, arg, first)
exarg_T *eap;
char_u *arg;
+ int *first;
{
int error = FALSE;
int len;
@@ -2091,15 +2106,15 @@ list_arg_vars(eap, arg)
{
switch (*name)
{
- case 'g': list_glob_vars(); break;
- case 'b': list_buf_vars(); break;
- case 'w': list_win_vars(); break;
+ case 'g': list_glob_vars(first); break;
+ case 'b': list_buf_vars(first); break;
+ case 'w': list_win_vars(first); break;
#ifdef FEAT_WINDOWS
- case 't': list_tab_vars(); break;
+ case 't': list_tab_vars(first); break;
#endif
- case 'v': list_vim_vars(); break;
- case 's': list_script_vars(); break;
- case 'l': list_func_vars(); break;
+ case 'v': list_vim_vars(first); break;
+ case 's': list_script_vars(first); break;
+ case 'l': list_func_vars(first); break;
default:
EMSG2(_("E738: Can't list variables for %s"), name);
}
@@ -2116,7 +2131,9 @@ list_arg_vars(eap, arg)
*arg = NUL;
list_one_var_a((char_u *)"",
arg == arg_subsc ? name : name_start,
- tv.v_type, s == NULL ? (char_u *)"" : s);
+ tv.v_type,
+ s == NULL ? (char_u *)"" : s,
+ first);
*arg = c;
vim_free(tf);
}
@@ -18001,9 +18018,10 @@ delete_var(ht, hi)
* List the value of one internal variable.
*/
static void
-list_one_var(v, prefix)
+list_one_var(v, prefix, first)
dictitem_T *v;
char_u *prefix;
+ int *first;
{
char_u *tofree;
char_u *s;
@@ -18011,16 +18029,17 @@ list_one_var(v, prefix)
s = echo_string(&v->di_tv, &tofree, numbuf, ++current_copyID);
list_one_var_a(prefix, v->di_key, v->di_tv.v_type,
- s == NULL ? (char_u *)"" : s);
+ s == NULL ? (char_u *)"" : s, first);
vim_free(tofree);
}
static void
-list_one_var_a(prefix, name, type, string)
+list_one_var_a(prefix, name, type, string, first)
char_u *prefix;
char_u *name;
int type;
char_u *string;
+ int *first; /* when TRUE clear rest of screen and set to FALSE */
{
/* don't use msg() or msg_attr() to avoid overwriting "v:statusmsg" */
msg_start();
@@ -18052,6 +18071,11 @@ list_one_var_a(prefix, name, type, string)
if (type == VAR_FUNC)
msg_puts((char_u *)"()");
+ if (*first)
+ {
+ msg_clr_eos();
+ *first = FALSE;
+ }
}
/*
diff --git a/src/version.c b/src/version.c
index f006e424..067f8e51 100644
--- a/src/version.c
+++ b/src/version.c
@@ -667,6 +667,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 89,
+/**/
88,
/**/
87,