2b37afcb36
1999-04-14 Andrew Haley <aph@cygnus.com> * java/lang/natDouble.java (doubleToLongBits): ensure that all NaNs are always converted to the same long value. * java/lang/natFloat.java (floatToIntBits): ditto, but for float converted to int. From-SVN: r26439
44 lines
709 B
C++
44 lines
709 B
C++
// natFloat.cc - Implementation of java.lang.Float native methods.
|
|
|
|
/* Copyright (C) 1998, 1999 Cygnus Solutions
|
|
|
|
This file is part of libgcj.
|
|
|
|
This software is copyrighted work licensed under the terms of the
|
|
Libgcj License. Please consult the file "LIBGCJ_LICENSE" for
|
|
details. */
|
|
|
|
#include <config.h>
|
|
|
|
#include <java/lang/Float.h>
|
|
#include <jvm.h>
|
|
|
|
union u
|
|
{
|
|
jint l;
|
|
jfloat d;
|
|
};
|
|
|
|
jint
|
|
java::lang::Float::floatToIntBits(jfloat value)
|
|
{
|
|
union u u;
|
|
u.d = value;
|
|
jint e = u.l & 0x7f800000;
|
|
jint f = u.l & 0x007fffff;
|
|
|
|
if (e == 0x7f800000 && f != 0)
|
|
u.l = 0x7fc00000;
|
|
|
|
return u.l;
|
|
}
|
|
|
|
jfloat
|
|
java::lang::Float::intBitsToFloat(jint bits)
|
|
{
|
|
union u u;
|
|
u.l = bits;
|
|
return u.d;
|
|
}
|
|
|