source: trunk/testcase/floatingpoint/jsnumexception.c@ 376

Last change on this file since 376 was 376, checked in by bird, 22 years ago

#563: let's get some output as well..

  • Property cvs2svn:cvs-rev set to 1.3
  • Property svn:eol-style set to native
  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
File size: 2.1 KB
Line 
1#include <stdio.h>
2#include <float.h>
3#include <signal.h>
4
5#define JSDOUBLE_HI32_SIGNBIT 0x80000000
6#define JSDOUBLE_HI32_EXPMASK 0x7ff00000
7#define JSDOUBLE_HI32_MANTMASK 0x000fffff
8#define JSVAL_INT_POW2(n) ((unsigned long)1 << (n))
9#define JSVAL_INT_MAX (JSVAL_INT_POW2(30) - 1)
10#define JSVAL_INT_MIN ((unsigned long)1 - JSVAL_INT_POW2(30))
11
12typedef unsigned uint32;
13typedef uint32 jsuint;
14typedef int jsint;
15
16
17#define JSDOUBLE_HI32(x) (((uint32 *)&(x))[1])
18#define JSDOUBLE_LO32(x) (((uint32 *)&(x))[0])
19
20#define JSDOUBLE_IS_NEGZERO(d) (JSDOUBLE_HI32(d) == JSDOUBLE_HI32_SIGNBIT && \
21 JSDOUBLE_LO32(d) == 0)
22#define JSDOUBLE_IS_FINITE(x) \
23 ((JSDOUBLE_HI32(x) & JSDOUBLE_HI32_EXPMASK) != JSDOUBLE_HI32_EXPMASK)
24
25#define JSDOUBLE_IS_INT(d, i) (JSDOUBLE_IS_FINITE(d) \
26 && !JSDOUBLE_IS_NEGZERO(d) \
27 && ((d) == (i = (jsint)(d))))
28
29#define INT_FITS_IN_JSVAL(i) ((jsuint)((i)+JSVAL_INT_MAX) <= 2*JSVAL_INT_MAX)
30
31
32int js_NewNumberValue(void *cx, double d, int *rval)
33{
34 int i = -1;
35 _control87(0x262, 0xFFF);
36#if 1
37 if ( JSDOUBLE_IS_INT(d, i)
38 && INT_FITS_IN_JSVAL(i))
39 {
40 *rval = i;
41 return 1;
42 }
43
44#else
45 if (((((unsigned *)&d)[1]) & JSDOUBLE_HI32_EXPMASK) != JSDOUBLE_HI32_EXPMASK )
46 if ( !((((unsigned *)&d)[1]) == JSDOUBLE_HI32_SIGNBIT && (((unsigned *)&d)[0]) == 0))
47 if (d == (i = (int)d))
48 if ((unsigned long)((i)+JSVAL_INT_MAX) <= 2*JSVAL_INT_MAX)
49 return i;
50#endif
51 *rval = i;
52 return 0;
53}
54
55void sigfun(int sig)
56{
57 printf("SIGFPE!\n");
58}
59
60int main()
61{
62 double rd1 = 0.0;
63 double rd2 = 1.000000000e8;
64 double rd3 = 2.147746133e9;
65 int l = -1;
66
67 _control87(0x262, 0xFFF);
68 signal(SIGFPE, sigfun);
69
70 l = -1;
71 js_NewNumberValue(NULL, rd1, &l);
72 printf("%11d %f\n", l, rd1);
73
74 l = -1;
75 js_NewNumberValue(NULL, rd2, &l);
76 printf("%11d %f\n", l, rd2);
77
78 l = -1;
79 js_NewNumberValue(NULL, rd3, &l);
80 printf("%11d %f\n", l, rd3);
81 return 0;
82}
83
Note: See TracBrowser for help on using the repository browser.