5c5367d377
The following updates in the JVM/IR plugin were made: * Lots of refactoring with preparation for K/N support: commonization of transformations. * Improved error handling (checks for visibility constraints, appending message about usage constraints in case of an error). * Explicit requirements for the visibility of atomic properties: to prevent leaking they should be private/internal or be members of private/internal classes. * Fixed visibility of generated properties: volatile properties are always private and atomic updaters have the same visibility as the original atomic property. * Volatile fields are generated from scratch and original atomic properties are removed. * Delegated properties support is fixed (only declaration in the same scope is allowed). * Non-inline atomic extensions are forbidden. * For top-level atomics: only one wrapper class per file (with corresponding visibility) is generated. * Bug fixes. The corresponding tickets: https://github.com/Kotlin/kotlinx-atomicfu/issues/322 KT-60528 Merge-request: KT-MR-10579 Merged-by: Maria Sokolova <maria.sokolova@jetbrains.com>
36 lines
846 B
Kotlin
Vendored
36 lines
846 B
Kotlin
Vendored
import kotlinx.atomicfu.*
|
|
import kotlin.test.*
|
|
|
|
class SimpleLockTest {
|
|
fun withLock() {
|
|
val lock = SimpleLock()
|
|
val result = lock.withLock {
|
|
"OK"
|
|
}
|
|
assertEquals("OK", result)
|
|
}
|
|
}
|
|
|
|
class SimpleLock {
|
|
private val _locked = atomic(0)
|
|
|
|
fun <T> withLock(block: () -> T): T {
|
|
// this contrieves construct triggers Kotlin compiler to reuse local variable slot #2 for
|
|
// the exception in `finally` clause
|
|
try {
|
|
_locked.loop { locked ->
|
|
check(locked == 0)
|
|
if (!_locked.compareAndSet(0, 1)) return@loop // continue
|
|
return block()
|
|
}
|
|
} finally {
|
|
_locked.value = 0
|
|
}
|
|
}
|
|
}
|
|
|
|
fun box(): String {
|
|
val testClass = SimpleLockTest()
|
|
testClass.withLock()
|
|
return "OK"
|
|
} |