// 
// Decompiled by Procyon v0.6.0
// 

package ch.randelshofer.fastdoubleparser;

import java.nio.charset.StandardCharsets;

final class JavaFloatBitsFromByteArray extends AbstractJavaFloatingPointBitsFromByteArray
{
    public JavaFloatBitsFromByteArray() {
    }
    
    @Override
    long nan() {
        return Float.floatToRawIntBits(Float.NaN);
    }
    
    @Override
    long negativeInfinity() {
        return Float.floatToRawIntBits(Float.NEGATIVE_INFINITY);
    }
    
    @Override
    long positiveInfinity() {
        return Float.floatToRawIntBits(Float.POSITIVE_INFINITY);
    }
    
    @Override
    long valueOfFloatLiteral(final byte[] str, final int startIndex, final int endIndex, final boolean isNegative, final long significand, final int exponent, final boolean isSignificandTruncated, final int exponentOfTruncatedSignificand) {
        final float result = FastFloatMath.tryDecFloatToFloatTruncated(isNegative, significand, exponent, isSignificandTruncated, exponentOfTruncatedSignificand);
        return Float.floatToRawIntBits(Float.isNaN(result) ? Float.parseFloat(new String(str, startIndex, endIndex - startIndex, StandardCharsets.ISO_8859_1)) : result);
    }
    
    @Override
    long valueOfHexLiteral(final byte[] str, final int startIndex, final int endIndex, final boolean isNegative, final long significand, final int exponent, final boolean isSignificandTruncated, final int exponentOfTruncatedSignificand) {
        final float d = FastFloatMath.tryHexFloatToFloatTruncated(isNegative, significand, exponent, isSignificandTruncated, exponentOfTruncatedSignificand);
        return Float.floatToRawIntBits(Float.isNaN(d) ? Float.parseFloat(new String(str, startIndex, endIndex - startIndex, StandardCharsets.ISO_8859_1)) : d);
    }
}
