summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--py/objfloat.c8
-rw-r--r--tests/float/float1.py19
2 files changed, 23 insertions, 4 deletions
diff --git a/py/objfloat.c b/py/objfloat.c
index eb59cc5b7..f74e12f9d 100644
--- a/py/objfloat.c
+++ b/py/objfloat.c
@@ -49,16 +49,16 @@ STATIC void float_print(const mp_print_t *print, mp_obj_t o_in, mp_print_kind_t
char buf[16];
mp_format_float(o->value, buf, sizeof(buf), 'g', 7, '\0');
mp_print_str(print, buf);
- if (strchr(buf, '.') == NULL && strchr(buf, 'e') == NULL) {
- // Python floats always have decimal point
+ if (strchr(buf, '.') == NULL && strchr(buf, 'e') == NULL && strchr(buf, 'n') == NULL) {
+ // Python floats always have decimal point (unless inf or nan)
mp_print_str(print, ".0");
}
#else
char buf[32];
sprintf(buf, "%.16g", (double) o->value);
mp_print_str(print, buf);
- if (strchr(buf, '.') == NULL && strchr(buf, 'e') == NULL) {
- // Python floats always have decimal point
+ if (strchr(buf, '.') == NULL && strchr(buf, 'e') == NULL && strchr(buf, 'n') == NULL) {
+ // Python floats always have decimal point (unless inf or nan)
mp_print_str(print, ".0");
}
#endif
diff --git a/tests/float/float1.py b/tests/float/float1.py
index bb670586a..f670a6348 100644
--- a/tests/float/float1.py
+++ b/tests/float/float1.py
@@ -7,6 +7,25 @@ print(1.2)
# float construction
print(float(1.2))
+print(float("1.2"))
+print(float("+1"))
+print(float("1e1"))
+print(float("1e+1"))
+print(float("1e-1"))
+print(float("inf"))
+print(float("INF"))
+print(float("infinity"))
+print(float("INFINITY"))
+print(float("nan"))
+print(float("NaN"))
+try:
+ float("1e+")
+except ValueError:
+ print("ValueError")
+try:
+ float("1z")
+except ValueError:
+ print("ValueError")
# unary operators
print(bool(0.0))