summary refs log blame commit diff stats
path: root/tests/float/tfloatnan.nim
blob: 9e3dd94f68da296ad1f488f3bdbc1f573712378f (plain) (tree)
1
2
3
4
5
6
7
8
           

           
                
                 


   




                             


                              
 
                   

























                                                                              












                                                          
discard """
output: '''
Nim: nan
Nim: nan (float)
Nim: nan (double)
'''
"""

let f = NaN
echo "Nim: ", f

let f32: float32 = NaN
echo "Nim: ", f32, " (float)"

let f64: float64 = NaN
echo "Nim: ", f64, " (double)"

block: # bug #10305
  # with `-O3 -ffast-math`, generated C/C++ code is not nan compliant
  # user can pass `--passC:-ffast-math` if he doesn't care.
  proc fun() =
    # this was previously failing at compile time with a nim compiler
    # that was compiled with `nim cpp -d:release`
    let a1 = 0.0
    let a = 0.0/a1
    let b1 = a == 0.0
    let b2 = a == a
    doAssert not b1
    doAssert not b2

  proc fun2(i: int) =
    # this was previously failing simply with `nim cpp -d:release`; the
    # difference with above example is that optimization (const folding) can't
    # take place in this example to hide the non-compliant nan bug.
    let a = 0.0/(i.float)
    let b1 = a == 0.0
    let b2 = a == a
    doAssert not b1
    doAssert not b2

  static: fun()
  fun()
  fun2(0)

template main() =
  # xxx move all tests under here
  block: # bug #16469
    let a1 = 0.0
    let a2 = -0.0
    let a3 = 1.0 / a1
    let a4 = 1.0 / a2
    doAssert a3 == Inf
    doAssert a4 == -Inf
    doAssert $(a1, a2, a3, a4) == "(0.0, -0.0, inf, -inf)"

static: main()
main()