27 lines
1.2 KiB
Java
27 lines
1.2 KiB
Java
package jxl.biff;
|
|
|
|
public class DoubleHelper {
|
|
public static double getIEEEDouble(byte[] data, int pos) {
|
|
int num1 = IntegerHelper.getInt(data[pos], data[pos + 1], data[pos + 2], data[pos + 3]);
|
|
int num2 = IntegerHelper.getInt(data[pos + 4], data[pos + 5], data[pos + 6], data[pos + 7]);
|
|
boolean negative = ((num2 & Integer.MIN_VALUE) != 0);
|
|
long val = (num2 & Integer.MAX_VALUE) * 4294967296L + ((num1 < 0) ? (4294967296L + num1) : num1);
|
|
double value = Double.longBitsToDouble(val);
|
|
if (negative)
|
|
value = -value;
|
|
return value;
|
|
}
|
|
|
|
public static void getIEEEBytes(double d, byte[] target, int pos) {
|
|
long val = Double.doubleToLongBits(d);
|
|
target[pos] = (byte)(int)(val & 0xFFL);
|
|
target[pos + 1] = (byte)(int)((val & 0xFF00L) >> 8L);
|
|
target[pos + 2] = (byte)(int)((val & 0xFF0000L) >> 16L);
|
|
target[pos + 3] = (byte)(int)((val & 0xFFFFFFFFFF000000L) >> 24L);
|
|
target[pos + 4] = (byte)(int)((val & 0xFF00000000L) >> 32L);
|
|
target[pos + 5] = (byte)(int)((val & 0xFF0000000000L) >> 40L);
|
|
target[pos + 6] = (byte)(int)((val & 0xFF000000000000L) >> 48L);
|
|
target[pos + 7] = (byte)(int)((val & 0xFF00000000000000L) >> 56L);
|
|
}
|
|
}
|