diff --git a/src/testdir/test_vim9_assign.vim b/src/testdir/test_vim9_assign.vim index 428de1c135..8491a4d879 100644 --- a/src/testdir/test_vim9_assign.vim +++ b/src/testdir/test_vim9_assign.vim @@ -245,6 +245,23 @@ def Test_assignment() END enddef +def Test_float_and_number() + if !has('float') + MissingFeature float + else + var lines =<< trim END + var f: float + f += 2 + f -= 1 + assert_equal(1.0, f) + ++f + --f + assert_equal(1.0, f) + END + CheckDefAndScriptSuccess(lines) + endif +enddef + let g:someNumber = 43 def Test_assign_concat() diff --git a/src/version.c b/src/version.c index cc8300be63..c6852f1e72 100644 --- a/src/version.c +++ b/src/version.c @@ -755,6 +755,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 3296, /**/ 3295, /**/ diff --git a/src/vim9compile.c b/src/vim9compile.c index 1c6e328f00..d2a6f68db0 100644 --- a/src/vim9compile.c +++ b/src/vim9compile.c @@ -7021,8 +7021,10 @@ compile_assignment(char_u *arg, exarg_T *eap, cmdidx_T cmdidx, cctx_T *cctx) // Special case: assigning to @# can use a number or a // string. - if (lhs_type == &t_number_or_string - && rhs_type->tt_type == VAR_NUMBER) + // Also: can assign a number to a float. + if ((lhs_type == &t_number_or_string + || lhs_type == &t_float) + && rhs_type->tt_type == VAR_NUMBER) lhs_type = &t_number; if (*p != '=' && need_type(rhs_type, lhs_type, -1, 0, cctx, FALSE, FALSE) == FAIL)