1999-04-07 22:42:40 +08:00
|
|
|
// natFloat.cc - Implementation of java.lang.Float native methods.
|
|
|
|
|
2000-01-20 02:39:27 +08:00
|
|
|
/* Copyright (C) 1998, 1999 Red Hat, Inc.
|
1999-04-07 22:42:40 +08:00
|
|
|
|
|
|
|
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;
|
1999-04-14 15:10:22 +08:00
|
|
|
jint e = u.l & 0x7f800000;
|
|
|
|
jint f = u.l & 0x007fffff;
|
|
|
|
|
|
|
|
if (e == 0x7f800000 && f != 0)
|
|
|
|
u.l = 0x7fc00000;
|
|
|
|
|
1999-04-07 22:42:40 +08:00
|
|
|
return u.l;
|
|
|
|
}
|
|
|
|
|
|
|
|
jfloat
|
|
|
|
java::lang::Float::intBitsToFloat(jint bits)
|
|
|
|
{
|
|
|
|
union u u;
|
|
|
|
u.l = bits;
|
|
|
|
return u.d;
|
|
|
|
}
|
|
|
|
|