mirror of git://gcc.gnu.org/git/gcc.git
				
				
				
			
		
			
				
	
	
		
			172 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Java
		
	
	
	
			
		
		
	
	
			172 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Java
		
	
	
	
/* Copyright (C) 1998, 1999, 2000  Free Software Foundation
 | 
						|
 | 
						|
   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.  */
 | 
						|
 
 | 
						|
package java.lang;
 | 
						|
 | 
						|
/**
 | 
						|
 * @author Andrew Haley <aph@cygnus.com>
 | 
						|
 * @date September 25, 1998.  
 | 
						|
 */
 | 
						|
/* Written using "Java Class Libraries", 2nd edition, ISBN 0-201-31002-3
 | 
						|
 * "The Java Language Specification", ISBN 0-201-63451-1
 | 
						|
 * plus online API docs for JDK 1.2 beta from http://www.javasoft.com.
 | 
						|
 * Status:  Believed complete and correct.
 | 
						|
 */
 | 
						|
 | 
						|
public final class Float extends Number implements Comparable
 | 
						|
{
 | 
						|
  public static final float MAX_VALUE = 3.4028235e+38f;
 | 
						|
  public static final float MIN_VALUE = 1.4e-45f;
 | 
						|
  public static final float NEGATIVE_INFINITY = -1.0f/0.0f;
 | 
						|
  public static final float POSITIVE_INFINITY = 1.0f/0.0f;
 | 
						|
  public static final float NaN = 0.0f/0.0f;
 | 
						|
 | 
						|
  // This initialization is seemingly circular, but it is accepted
 | 
						|
  // by javac, and is handled specially by gcc.
 | 
						|
  public static final Class TYPE = float.class;
 | 
						|
 | 
						|
  private float value;
 | 
						|
 | 
						|
  private static final long serialVersionUID = -2671257302660747028L;
 | 
						|
 | 
						|
  public Float (float value)
 | 
						|
  {
 | 
						|
    this.value = value;
 | 
						|
  }
 | 
						|
 | 
						|
  public Float (double value)
 | 
						|
  {
 | 
						|
    this.value = (float)value;
 | 
						|
  }
 | 
						|
 | 
						|
  public Float (String s) throws NumberFormatException
 | 
						|
  {
 | 
						|
    this.value = valueOf (s).floatValue ();
 | 
						|
  }
 | 
						|
 | 
						|
  public String toString ()
 | 
						|
  {
 | 
						|
    return toString (value);
 | 
						|
  }
 | 
						|
 | 
						|
  public boolean equals (Object obj)
 | 
						|
  {
 | 
						|
    if (obj == null)
 | 
						|
      return false;
 | 
						|
 | 
						|
    if (!(obj instanceof Float))
 | 
						|
      return false;
 | 
						|
 | 
						|
    Float f = (Float) obj;
 | 
						|
 | 
						|
    return floatToIntBits (value) == floatToIntBits (f.floatValue ());
 | 
						|
  }
 | 
						|
 | 
						|
  public int hashCode ()
 | 
						|
  {
 | 
						|
    return floatToIntBits (value);
 | 
						|
  }
 | 
						|
 | 
						|
  public int intValue ()
 | 
						|
  {
 | 
						|
    return (int) value;
 | 
						|
  }
 | 
						|
 | 
						|
  public long longValue ()
 | 
						|
  {
 | 
						|
    return (long) value;
 | 
						|
  }
 | 
						|
 | 
						|
  public float floatValue ()
 | 
						|
  {
 | 
						|
    return (float) value;
 | 
						|
  }
 | 
						|
 | 
						|
  public double doubleValue ()
 | 
						|
  {
 | 
						|
    return (double) value;
 | 
						|
  }
 | 
						|
 | 
						|
  public byte byteValue ()
 | 
						|
  {
 | 
						|
    return (byte) value;
 | 
						|
  }
 | 
						|
 | 
						|
  public short shortValue ()
 | 
						|
  {
 | 
						|
    return (short) value;
 | 
						|
  }
 | 
						|
 | 
						|
  public static String toString (float v)
 | 
						|
  {
 | 
						|
    return Double.toString ((double) v, true);
 | 
						|
  } 
 | 
						|
 | 
						|
  public static Float valueOf (String s) throws NullPointerException, 
 | 
						|
    NumberFormatException
 | 
						|
  {
 | 
						|
    if (s == null)
 | 
						|
      throw new NullPointerException ();
 | 
						|
 | 
						|
    return new Float (Double.valueOf (s).floatValue ());
 | 
						|
  }
 | 
						|
 | 
						|
  public boolean isNaN ()
 | 
						|
  {
 | 
						|
    return isNaN (value);
 | 
						|
  }
 | 
						|
 | 
						|
  public static boolean isNaN (float v)
 | 
						|
  {
 | 
						|
    int bits = floatToIntBits (v);
 | 
						|
    int e = bits & 0x7f800000;
 | 
						|
    int f = bits & 0x007fffff;
 | 
						|
 | 
						|
    return e == 0x7f800000 && f != 0;
 | 
						|
  }
 | 
						|
 | 
						|
  public boolean isInfinite ()
 | 
						|
  {
 | 
						|
    return isInfinite (value);
 | 
						|
  }
 | 
						|
 | 
						|
  public static boolean isInfinite (float v)
 | 
						|
  {
 | 
						|
    int bits = floatToIntBits (v);
 | 
						|
    int f = bits & 0x7fffffff;
 | 
						|
 | 
						|
    return f == 0x7f800000;
 | 
						|
  }
 | 
						|
 | 
						|
  public static native int floatToIntBits (float value);
 | 
						|
 | 
						|
  public static native float intBitsToFloat (int bits);
 | 
						|
 | 
						|
  public int compareTo (Float d)
 | 
						|
  {
 | 
						|
    float v = d.value;
 | 
						|
    if (isNaN (value))
 | 
						|
      return isNaN (v) ? 1 : 0;
 | 
						|
    else if (isNaN (v))
 | 
						|
      return -1;
 | 
						|
    else if (value == 0.0 && v == -0.0)
 | 
						|
      return 1;
 | 
						|
    else if (value == -0.0 && v == 0.0)
 | 
						|
      return -1;
 | 
						|
    else if (value == v)
 | 
						|
      return 0;
 | 
						|
 | 
						|
    return value > v ? 1 : -1;
 | 
						|
  }
 | 
						|
 | 
						|
  public int compareTo (Object o)
 | 
						|
  {
 | 
						|
    return compareTo ((Float) o);
 | 
						|
  }
 | 
						|
}
 |