blob: 2f7ce8c601431656363ff6da18be6fc70811ef33 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
#include <limits.h>
#include "ruby.h"
int
signbit(double x)
{
enum {double_per_long = sizeof(double) / sizeof(long)};
enum {long_msb = sizeof(long) * CHAR_BIT - 1};
union {double d; unsigned long i[double_per_long];} u;
unsigned long l;
u.d = x;
#ifdef WORDS_BIGENDIAN
l = u.i[0];
#else
l = u.i[double_per_long - 1];
#endif
return (int)(l >> long_msb);
}
|