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:
@@ -2045,6 +2045,13 @@ def Test_expr9_number()
|
|||||||
assert_equal(6, 0x6)
|
assert_equal(6, 0x6)
|
||||||
assert_equal(15, 0xf)
|
assert_equal(15, 0xf)
|
||||||
assert_equal(255, 0xff)
|
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
|
END
|
||||||
v9.CheckDefAndScriptSuccess(lines)
|
v9.CheckDefAndScriptSuccess(lines)
|
||||||
enddef
|
enddef
|
||||||
|
@@ -695,6 +695,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
1107,
|
||||||
/**/
|
/**/
|
||||||
1106,
|
1106,
|
||||||
/**/
|
/**/
|
||||||
|
@@ -1757,22 +1757,14 @@ compile_leader(cctx_T *cctx, int numeric_only, char_u *start, char_u **end)
|
|||||||
--p;
|
--p;
|
||||||
if (*p == '-' || *p == '+')
|
if (*p == '-' || *p == '+')
|
||||||
{
|
{
|
||||||
int negate = *p == '-';
|
type_T *type = get_type_on_stack(cctx, 0);
|
||||||
isn_T *isn;
|
if (type->tt_type != VAR_FLOAT && need_type(type, &t_number,
|
||||||
type_T *type;
|
|
||||||
|
|
||||||
type = get_type_on_stack(cctx, 0);
|
|
||||||
if (type != &t_float && need_type(type, &t_number,
|
|
||||||
-1, 0, cctx, FALSE, FALSE) == FAIL)
|
-1, 0, cctx, FALSE, FALSE) == FAIL)
|
||||||
return FAIL;
|
return FAIL;
|
||||||
|
|
||||||
// only '-' has an effect, for '+' we only check the type
|
// only '-' has an effect, for '+' we only check the type
|
||||||
if (negate)
|
if (*p == '-' && generate_instr(cctx, ISN_NEGATENR) == NULL)
|
||||||
{
|
return FAIL;
|
||||||
isn = generate_instr(cctx, ISN_NEGATENR);
|
|
||||||
if (isn == NULL)
|
|
||||||
return FAIL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else if (numeric_only)
|
else if (numeric_only)
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user