This source file includes following definitions.
- main
 
   1 
   2 
   3 
   4 
   5 
   6 
   7 
   8 
   9 
  10 
  11 
  12 
  13 
  14 
  15 
  16 
  17 
  18 
  19 #include <limits.h>
  20 
  21 #include "minus-zero.h"
  22 #include "infinity.h"
  23 #include "nan.h"
  24 #include "macros.h"
  25 
  26 int
  27 main ()
     
  28 {
  29   
  30   ASSERT (!isnanf (3.141f));
  31   ASSERT (!isnanf (3.141e30f));
  32   ASSERT (!isnanf (3.141e-30f));
  33   ASSERT (!isnanf (-2.718f));
  34   ASSERT (!isnanf (-2.718e30f));
  35   ASSERT (!isnanf (-2.718e-30f));
  36   ASSERT (!isnanf (0.0f));
  37   ASSERT (!isnanf (minus_zerof));
  38   
  39   ASSERT (!isnanf (Infinityf ()));
  40   ASSERT (!isnanf (- Infinityf ()));
  41   
  42   ASSERT (isnanf (NaNf ()));
  43 #if defined FLT_EXPBIT0_WORD && defined FLT_EXPBIT0_BIT
  44   
  45   {
  46     #define NWORDS \
  47       ((sizeof (float) + sizeof (unsigned int) - 1) / sizeof (unsigned int))
  48     typedef union { float value; unsigned int word[NWORDS]; } memory_float;
  49     memory_float m;
  50     m.value = NaNf ();
  51 # if FLT_EXPBIT0_BIT > 0
  52     m.word[FLT_EXPBIT0_WORD] ^= (unsigned int) 1 << (FLT_EXPBIT0_BIT - 1);
  53 # else
  54     m.word[FLT_EXPBIT0_WORD + (FLT_EXPBIT0_WORD < NWORDS / 2 ? 1 : - 1)]
  55       ^= (unsigned int) 1 << (sizeof (unsigned int) * CHAR_BIT - 1);
  56 # endif
  57     if (FLT_EXPBIT0_WORD < NWORDS / 2)
  58       m.word[FLT_EXPBIT0_WORD + 1] |= (unsigned int) 1 << FLT_EXPBIT0_BIT;
  59     else
  60       m.word[0] |= (unsigned int) 1;
  61     ASSERT (isnanf (m.value));
  62   }
  63 #endif
  64   return 0;
  65 }