circuitpython/tests/unix/ffi_float.py

34 lines
775 B
Python
Raw Normal View History

# test ffi float support
try:
import ffi
except ImportError:
print("SKIP")
raise SystemExit
def ffi_open(names):
err = None
for n in names:
try:
mod = ffi.open(n)
return mod
except OSError as e:
err = e
raise err
2021-03-15 19:27:36 +05:30
libc = ffi_open(("libc.so", "libc.so.0", "libc.so.6", "libc.dylib"))
strtof = libc.func("f", "strtof", "sp")
2021-03-15 19:27:36 +05:30
print("%.6f" % strtof("1.23", None))
strtod = libc.func("d", "strtod", "sp")
2021-03-15 19:27:36 +05:30
print("%.6f" % strtod("1.23", None))
# test passing double and float args
2021-03-15 19:27:36 +05:30
libm = ffi_open(("libm.so", "libm.so.6", "libc.so.0", "libc.so.6", "libc.dylib"))
tgamma = libm.func("d", "tgamma", "d")
for fun in (tgamma,):
for val in (0.5, 1, 1.0, 1.5, 4, 4.0):
2021-03-15 19:27:36 +05:30
print("%.6f" % fun(val))