64 lines
1.9 KiB
Kotlin
64 lines
1.9 KiB
Kotlin
/*
|
|
* Copyright 2010-2020 JetBrains s.r.o. and Kotlin Programming Language contributors.
|
|
* Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.
|
|
*/
|
|
|
|
package kotlin.js
|
|
|
|
// TODO use declarations from stdlib
|
|
private external class ArrayBuffer(size: Int)
|
|
private external class Float64Array(buffer: ArrayBuffer)
|
|
private external class Float32Array(buffer: ArrayBuffer)
|
|
private external class Int32Array(buffer: ArrayBuffer)
|
|
|
|
private val buf = ArrayBuffer(8)
|
|
// TODO use one DataView instead of bunch of typed views.
|
|
private val bufFloat64 = Float64Array(buf).unsafeCast<DoubleArray>()
|
|
private val bufFloat32 = Float32Array(buf).unsafeCast<FloatArray>()
|
|
private val bufInt32 = Int32Array(buf).unsafeCast<IntArray>()
|
|
|
|
private val lowIndex = run {
|
|
bufFloat64[0] = -1.0 // bff00000_00000000
|
|
if (bufInt32[0] != 0) 1 else 0
|
|
}
|
|
private val highIndex = 1 - lowIndex
|
|
|
|
internal fun doubleToRawBits(value: Double): Long {
|
|
bufFloat64[0] = value
|
|
return Long(bufInt32[lowIndex], bufInt32[highIndex])
|
|
}
|
|
|
|
@PublishedApi
|
|
internal fun doubleFromBits(value: Long): Double {
|
|
bufInt32[lowIndex] = value.low
|
|
bufInt32[highIndex] = value.high
|
|
return bufFloat64[0]
|
|
}
|
|
|
|
internal fun floatToRawBits(value: Float): Int {
|
|
bufFloat32[0] = value
|
|
return bufInt32[0]
|
|
}
|
|
|
|
@PublishedApi
|
|
internal fun floatFromBits(value: Int): Float {
|
|
bufInt32[0] = value
|
|
return bufFloat32[0]
|
|
}
|
|
|
|
// returns zero value for number with positive sign bit and non-zero value for number with negative sign bit.
|
|
internal fun doubleSignBit(value: Double): Int {
|
|
bufFloat64[0] = value
|
|
return bufInt32[highIndex] and Int.MIN_VALUE
|
|
}
|
|
|
|
internal fun getNumberHashCode(obj: Double): Int {
|
|
@Suppress("DEPRECATED_IDENTITY_EQUALS")
|
|
if (jsBitwiseOr(obj, 0).unsafeCast<Double>() === obj) {
|
|
return obj.toInt()
|
|
}
|
|
|
|
bufFloat64[0] = obj
|
|
return bufInt32[highIndex] * 31 + bufInt32[lowIndex]
|
|
}
|