corda/classpath/java/lang/Long.java

152 lines
3.2 KiB
Java
Raw Normal View History

/* Copyright (c) 2008, Avian Contributors
Permission to use, copy, modify, and/or distribute this software
for any purpose with or without fee is hereby granted, provided
that the above copyright notice and this permission notice appear
in all copies.
There is NO WARRANTY for this software. See license.txt for
details. */
package java.lang;
public final class Long extends Number implements Comparable<Long> {
public static final Long MIN_VALUE = -9223372036854775808l;
public static final Long MAX_VALUE = 9223372036854775807l;
public static final Class TYPE = Class.forCanonicalName("J");
2007-07-26 20:39:53 -06:00
private final long value;
public Long(long value) {
this.value = value;
}
2007-09-13 20:19:44 -06:00
public Long(String s) {
this.value = parseLong(s);
}
2007-09-26 10:32:02 -06:00
public static Long valueOf(String value) {
return new Long(value);
}
public static Long valueOf(long value) {
return new Long(value);
}
public int compareTo(Long o) {
return value > o.value ? 1 : (value < o.value ? -1 : 0);
}
public boolean equals(Object o) {
return o instanceof Long && ((Long) o).value == value;
}
public int hashCode() {
return (int) ((value >> 32) ^ (value & 0xFF));
}
public String toString() {
return String.valueOf(value);
}
public static String toString(long v, int radix) {
if (radix < 1 || radix > 36) {
throw new IllegalArgumentException("radix " + radix + " not in [1,36]");
}
if (v == 0) {
return "0";
}
2007-08-19 20:57:32 -06:00
boolean negative = v < 0;
if (negative) v = -v;
int size = (negative ? 1 : 0);
for (long n = v; n > 0; n /= radix) ++size;
char[] array = new char[size];
int i = array.length - 1;
for (long n = v; n > 0; n /= radix) {
long digit = n % radix;
if (digit >= 0 && digit <= 9) {
array[i] = (char) ('0' + digit);
} else {
array[i] = (char) ('a' + (digit - 10));
}
--i;
}
2007-08-19 20:57:32 -06:00
if (negative) {
array[i] = '-';
}
return new String(array);
}
public static String toString(long v) {
return toString(v, 10);
}
public byte byteValue() {
return (byte) value;
}
public short shortValue() {
return (short) value;
}
public int intValue() {
return (int) value;
}
public long longValue() {
return value;
}
public float floatValue() {
return (float) value;
}
public double doubleValue() {
return (double) value;
}
2007-07-27 17:56:19 -06:00
private static long pow(long a, long b) {
long c = 1;
for (int i = 0; i < b; ++i) c *= a;
return c;
}
2007-08-02 19:49:32 -06:00
public static long parseLong(String s) {
return parseLong(s, 10);
}
public static long parseLong(String s, int radix) {
int i = 0;
2007-07-27 17:56:19 -06:00
long number = 0;
boolean negative = s.startsWith("-");
if (negative) {
i = 1;
}
2007-07-27 17:56:19 -06:00
for (; i < s.length(); ++i) {
2007-07-27 17:56:19 -06:00
char c = s.charAt(i);
int digit = Character.digit(c, radix);
if (digit >= 0) {
number += digit * pow(radix, (s.length() - i - 1));
} else {
throw new NumberFormatException("invalid character " + c + " code " +
(int) c);
2007-07-27 17:56:19 -06:00
}
}
if (negative) {
number = -number;
2007-07-27 17:56:19 -06:00
}
return number;
}
}