commonMain.dev.datlag.tooling.decompose.SynchronizedObject.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of tooling-decompose-jvm Show documentation
Show all versions of tooling-decompose-jvm Show documentation
Kotlin multiplatform tooling library.
package dev.datlag.tooling.decompose
/*
* Copyright 2024 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import kotlin.contracts.ExperimentalContracts
import kotlin.contracts.InvocationKind
import kotlin.contracts.contract
/**
* A [SynchronizedObject] provides a mechanism for thread coordination. Instances of this class
* are used within [synchronized] functions to establish mutual exclusion, guaranteeing that only
* one thread accesses a protected resource or code block at a time.
*/
internal expect class SynchronizedObject()
/**
* Executes the given function [action] while holding the monitor of the given object [lock].
*
* The implementation is platform specific:
* - JVM: implemented via `synchronized`, `ReentrantLock` is avoided for performance reasons.
* - Native: implemented via POSIX mutex with `PTHREAD_MUTEX_RECURSIVE` flag.
*/
@OptIn(ExperimentalContracts::class)
internal inline fun synchronized(lock: SynchronizedObject, crossinline action: () -> T): T {
contract { callsInPlace(action, InvocationKind.EXACTLY_ONCE) }
return synchronizedImpl(lock, action)
}
/**
* Executes the given function [action] while holding the monitor of the given object [lock].
*
* The implementation is platform specific:
* - JVM: implemented via `synchronized`, `ReentrantLock` is avoided for performance reasons.
* - Native: implemented via POSIX mutex with `PTHREAD_MUTEX_RECURSIVE` flag.
*
* **This is a private API and should not be used from general code.** This function exists
* primarily as a workaround for a Kotlin issue
* ([KT-29963](https://youtrack.jetbrains.com/issue/KT-29963)).
*
* You **MUST** use [synchronized] instead.
*/
internal expect inline fun synchronizedImpl(
lock: SynchronizedObject,
crossinline action: () -> T,
): T
© 2015 - 2025 Weber Informatics LLC | Privacy Policy