/trunk/Examples/test-suite/python/virtual_poly_runme.py
Python | 38 lines | 21 code | 11 blank | 6 comment | 6 complexity | cf4e019df53bede8f57a4c4a1c04da38 MD5 | raw file
Possible License(s): LGPL-2.1, Cube, GPL-3.0, 0BSD, GPL-2.0
- import virtual_poly
- d = virtual_poly.NDouble(3.5)
- i = virtual_poly.NInt(2)
- #
- # the copy methods return the right polymorphic types
- #
- dc = d.copy()
- ic = i.copy()
- if d.get() != dc.get():
- raise RuntimeError
- if i.get() != ic.get():
- raise RuntimeError
- virtual_poly.incr(ic)
- if (i.get() + 1) != ic.get():
- raise RuntimeError
- dr = d.ref_this()
- if d.get() != dr.get():
- raise RuntimeError
- #
- # 'narrowing' also works
- #
- ddc = virtual_poly.NDouble_narrow(d.nnumber())
- if d.get() != ddc.get():
- raise RuntimeError
- dic = virtual_poly.NInt_narrow(i.nnumber())
- if i.get() != dic.get():
- raise RuntimeError