Files
kotlin-fork/plugins/atomicfu/atomicfu-compiler/testData/box/LockFreeIntBitsTest.kt
T
mvicsokolova 8053746ae0 kotlinx.atomicfu JVM/IR compiler plugin support
Merge-request: KT-MR-6541
Merged-by: Maria Sokolova <maria.sokolova@jetbrains.com>
2022-06-26 07:17:06 +00:00

57 lines
1.3 KiB
Kotlin
Vendored

import kotlinx.atomicfu.*
import kotlin.test.*
class LockFreeIntBitsTest {
fun testBasic() {
val bs = LockFreeIntBits()
assertTrue(!bs[0])
assertTrue(bs.bitSet(0))
assertTrue(bs[0])
assertTrue(!bs.bitSet(0))
assertTrue(!bs[1])
assertTrue(bs.bitSet(1))
assertTrue(bs[1])
assertTrue(!bs.bitSet(1))
assertTrue(!bs.bitSet(0))
assertTrue(bs[0])
assertTrue(bs.bitClear(0))
assertTrue(!bs.bitClear(0))
assertTrue(bs[1])
}
}
class LockFreeIntBits {
private val bits = atomic(0)
private fun Int.mask() = 1 shl this
operator fun get(index: Int): Boolean = bits.value and index.mask() != 0
// User-defined private inline function
private inline fun bitUpdate(check: (Int) -> Boolean, upd: (Int) -> Int): Boolean {
bits.update {
if (check(it)) return false
upd(it)
}
return true
}
fun bitSet(index: Int): Boolean {
val mask = index.mask()
return bitUpdate({ it and mask != 0 }, { it or mask })
}
fun bitClear(index: Int): Boolean {
val mask = index.mask()
return bitUpdate({ it and mask == 0 }, { it and mask.inv() })
}
}
fun box(): String {
val testClass = LockFreeIntBitsTest()
testClass.testBasic()
return "OK"
}