v/vlib/strconv/atof_test.v

75 lines
1.3 KiB
V
Raw Normal View History

2019-12-16 23:07:13 +01:00
/**********************************************************************
*
* String to float Test
*
**********************************************************************/
2019-12-27 04:07:09 +01:00
import (
strconv
strconv.atofq
)
2019-12-16 23:07:13 +01:00
fn test_atof() {
//
// test set
//
// float64
src_num := [
2019-12-27 04:07:09 +01:00
f64(0.3),
-0.3,
0.004,
-0.004,
0.0,
-0.0,
31234567890123
2019-12-16 23:07:13 +01:00
]
// strings
src_num_str := [
'0.3',
'-0.3',
'0.004',
'-0.004',
'0.0',
'-0.0',
'31234567890123',
2019-12-16 23:07:13 +01:00
]
// check conversion case 1 string <=> string
2019-12-16 23:07:13 +01:00
for c,x in src_num {
// slow atof
2019-12-16 23:07:13 +01:00
assert strconv.atof64(src_num_str[c]).strlong() == x.strlong()
2019-12-27 04:07:09 +01:00
// quick atof
2019-12-27 04:07:09 +01:00
mut s1 := (atofq.atof_quick(src_num_str[c]).str())
s1 = s1[..src_num_str[c].len]
mut s2 := (x.str())
s2 = s2[..src_num_str[c].len]
assert s1 == s2
// test C.atof
2019-12-16 23:07:13 +01:00
assert x.strsci(18) == f64(C.atof(src_num_str[c].str)).strsci(18)
}
// check conversion case 2 string <==> f64
// we don't test atof_quick beacuse we already know the rounding error
2019-12-16 23:07:13 +01:00
for c,x in src_num_str {
b := src_num[c].strlong()
a1 := strconv.atof64(x).strlong()
assert a1 == b
2019-12-16 23:07:13 +01:00
}
// special cases
mut f1 := f64(0.0)
mut ptr := *u64(&f1)
ptr = *u64(&f1)
// DOUBLE_PLUS_ZERO
f1=0.0
assert *ptr == u64(0x0000000000000000)
// DOUBLE_MINUS_ZERO
f1=-0.0
assert *ptr == u64(0x8000000000000000)
2019-12-27 04:07:09 +01:00
}