Files
HRMS/hrmsEjb/jxl/biff/DoubleHelper.java
2025-07-28 13:56:49 +05:30

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);
}
}