import strconv /********************************************************************** * * String to float Test * **********************************************************************/ fn test_atof() { // // test set // // float64 src_num := [ f64(0.3), -0.3, 0.004, -0.004, 0.0, -0.0, 31234567890123, ] // strings src_num_str := [ '0.3', '-0.3', '0.004', '-0.004', '0.0', '-0.0', '31234567890123', ] // check conversion case 1 string <=> string for c, x in src_num { // slow atof val := strconv.atof64(src_num_str[c]) or { panic(err) } assert val.strlong() == x.strlong() // quick atof mut s1 := (strconv.atof_quick(src_num_str[c]).str()) mut s2 := (x.str()) delta := s1.f64() - s2.f64() // println("$s1 $s2 $delta") assert delta < f64(1e-16) // test C.atof n1 := x.strsci(18) n2 := f64(C.atof(&char(src_num_str[c].str))).strsci(18) // println("$n1 $n2") assert n1 == n2 } // check conversion case 2 string <==> f64 // we don't test atof_quick beacuse we already know the rounding error for c, x in src_num_str { b := src_num[c].strlong() value := strconv.atof64(x) or { panic(err) } a1 := value.strlong() assert a1 == b } // special cases mut f1 := f64(0.0) mut ptr := unsafe { &u64(&f1) } ptr = unsafe { &u64(&f1) } // double_plus_zero f1 = 0.0 assert *ptr == u64(0x0000000000000000) // double_minus_zero f1 = -0.0 assert *ptr == u64(0x8000000000000000) println('DONE!') } fn test_atof_errors() { if x := strconv.atof64('') { eprintln('> x: ${x}') assert false // strconv.atof64 should have failed } else { assert err.str() == 'expected a number found an empty string' } if x := strconv.atof64('####') { eprintln('> x: ${x}') assert false // strconv.atof64 should have failed } else { assert err.str() == 'not a number' } }