# HG changeset patch # User Bram Moolenaar # Date 1371067738 -7200 # Node ID b7bb20390111b75616eb66558aa9517901eb0144 # Parent a5352e73dc008133d066b81da581e2a2562ddb47 updated for version 7.3.1181 Problem: Wrong error message for 1.0[0]. Solution: Check for funcref and float separately. (Yasuhiro Matsumoto) diff --git a/src/eval.c b/src/eval.c --- a/src/eval.c +++ b/src/eval.c @@ -112,6 +112,7 @@ static char *e_dictrange = N_("E719: Can static char *e_letwrong = N_("E734: Wrong variable type for %s="); static char *e_nofunc = N_("E130: Unknown function: %s"); static char *e_illvar = N_("E461: Illegal variable name: %s"); +static char *e_float_as_string = N_("E806: using Float as a String"); static dictitem_T globvars_var; /* variable used for g: */ #define globvarht globvardict.dv_hashtab @@ -5268,16 +5269,20 @@ eval_index(arg, rettv, evaluate, verbose char_u *s; char_u *key = NULL; - if (rettv->v_type == VAR_FUNC -#ifdef FEAT_FLOAT - || rettv->v_type == VAR_FLOAT -#endif - ) + if (rettv->v_type == VAR_FUNC) { if (verbose) EMSG(_("E695: Cannot index a Funcref")); return FAIL; } +#ifdef FEAT_FLOAT + else if (rettv->v_type == VAR_FLOAT) + { + if (verbose) + EMSG(_(e_float_as_string)); + return FAIL; + } +#endif if (**arg == '.') { @@ -20085,7 +20090,7 @@ get_tv_string_buf_chk(varp, buf) break; #ifdef FEAT_FLOAT case VAR_FLOAT: - EMSG(_("E806: using Float as a String")); + EMSG(_(e_float_as_string)); break; #endif case VAR_STRING: diff --git a/src/version.c b/src/version.c --- a/src/version.c +++ b/src/version.c @@ -729,6 +729,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 1181, +/**/ 1180, /**/ 1179,