Skip to content

Commit

Permalink
kernel: raise error if eager float literal conversion fails
Browse files Browse the repository at this point in the history
  • Loading branch information
fingolfin committed Apr 17, 2018
1 parent 5fc61d8 commit 0f4d9b8
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 1 deletion.
5 changes: 4 additions & 1 deletion src/intrprtr.c
Original file line number Diff line number Diff line change
Expand Up @@ -1804,7 +1804,10 @@ static Obj ConvertFloatLiteralEager(Obj str)
SET_LEN_STRING(str, len - 2);
chars[len - 2] = '\0';
}
return CALL_2ARGS(CONVERT_FLOAT_LITERAL_EAGER, str, ObjsChar[(UInt)mark]);
Obj res = CALL_2ARGS(CONVERT_FLOAT_LITERAL_EAGER, str, ObjsChar[(UInt)mark]);
if (res == Fail)
ErrorQuit("failed to convert float literal", 0, 0);
return res;
}

void IntrFloatExpr (
Expand Down
21 changes: 21 additions & 0 deletions tst/testinstall/float.tst
Original file line number Diff line number Diff line change
Expand Up @@ -237,6 +237,27 @@ false
gap> EqFloat(0.0,0.0/0.0);
false

#
# float literals in the REPL
#
gap> 1.1;
1.1
gap> 1.1_;
1.1
gap> 1.x1;
Syntax error: Badly formed number in stream:1
1.x1;
^
gap> 1.1xx;
Syntax error: Badly formed number in stream:1
1.1xx;
^

# The following is potentially correct, *if* there is a conversion handler for
# 'x' installed, which normally isn't the case.
gap> 1.1x;
Error, failed to convert float literal

#
# float literal expressions in functions
#
Expand Down

0 comments on commit 0f4d9b8

Please sign in to comment.