1
0
forked from aniani/vim

patch 9.0.1107: float constant not recognized as float

Problem:    Float constant not recognized as float.
Solution:   Check the vartype instead of comparing with t_float.
            (closes #11754)
This commit is contained in:
Bram Moolenaar 2022-12-27 20:54:41 +00:00
parent 09ce0b8e11
commit 73ade49c4b
3 changed files with 13 additions and 12 deletions

View File

@ -2045,6 +2045,13 @@ def Test_expr9_number()
assert_equal(6, 0x6)
assert_equal(15, 0xf)
assert_equal(255, 0xff)
const INFTY = 1.0 / 0.0
def Test()
assert_equal(1, isinf(INFTY))
assert_equal(-1, isinf(-INFTY))
enddef
Test()
END
v9.CheckDefAndScriptSuccess(lines)
enddef

View File

@ -695,6 +695,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
1107,
/**/
1106,
/**/

View File

@ -1757,22 +1757,14 @@ compile_leader(cctx_T *cctx, int numeric_only, char_u *start, char_u **end)
--p;
if (*p == '-' || *p == '+')
{
int negate = *p == '-';
isn_T *isn;
type_T *type;
type = get_type_on_stack(cctx, 0);
if (type != &t_float && need_type(type, &t_number,
type_T *type = get_type_on_stack(cctx, 0);
if (type->tt_type != VAR_FLOAT && need_type(type, &t_number,
-1, 0, cctx, FALSE, FALSE) == FAIL)
return FAIL;
// only '-' has an effect, for '+' we only check the type
if (negate)
{
isn = generate_instr(cctx, ISN_NEGATENR);
if (isn == NULL)
return FAIL;
}
if (*p == '-' && generate_instr(cctx, ISN_NEGATENR) == NULL)
return FAIL;
}
else if (numeric_only)
{