Skip to content
This repository has been archived by the owner on Feb 9, 2024. It is now read-only.

Commit

Permalink
Kotlin 1.4.21 + WorkerBoundReference (#76)
Browse files Browse the repository at this point in the history
  • Loading branch information
Ben Asher authored Jan 11, 2021
1 parent c007791 commit 1c800aa
Show file tree
Hide file tree
Showing 6 changed files with 11 additions and 26 deletions.
4 changes: 2 additions & 2 deletions build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ val coroutinesVersion = "1.3.9"
val atomicfuVersion = "0.14.4"

plugins {
kotlin("multiplatform") version "1.4.10"
kotlin("multiplatform") version "1.4.21"
id("org.jetbrains.dokka") version "0.10.0"
id("maven-publish")
id("signing")
Expand Down Expand Up @@ -103,7 +103,7 @@ kotlin {
val ktlintConfig by configurations.creating

dependencies {
ktlintConfig("com.pinterest:ktlint:0.37.2")
ktlintConfig("com.pinterest:ktlint:0.40.0")
}

val ktlint by tasks.registering(JavaExec::class) {
Expand Down
Binary file modified gradle/wrapper/gradle-wrapper.jar
Binary file not shown.
2 changes: 1 addition & 1 deletion gradle/wrapper/gradle-wrapper.properties
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-6.7.1-bin.zip
distributionUrl=https\://services.gradle.org/distributions/gradle-6.8-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
2 changes: 1 addition & 1 deletion gradlew
Original file line number Diff line number Diff line change
Expand Up @@ -130,7 +130,7 @@ fi
if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then
APP_HOME=`cygpath --path --mixed "$APP_HOME"`
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`

JAVACMD=`cygpath --unix "$JAVACMD"`

# We build the pattern for arguments to be converted via cygpath
Expand Down
21 changes: 3 additions & 18 deletions gradlew.bat
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ if defined JAVA_HOME goto findJavaFromJavaHome

set JAVA_EXE=java.exe
%JAVA_EXE% -version >NUL 2>&1
if "%ERRORLEVEL%" == "0" goto init
if "%ERRORLEVEL%" == "0" goto execute

echo.
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
Expand All @@ -54,7 +54,7 @@ goto fail
set JAVA_HOME=%JAVA_HOME:"=%
set JAVA_EXE=%JAVA_HOME%/bin/java.exe

if exist "%JAVA_EXE%" goto init
if exist "%JAVA_EXE%" goto execute

echo.
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
Expand All @@ -64,29 +64,14 @@ echo location of your Java installation.

goto fail

:init
@rem Get command-line arguments, handling Windows variants

if not "%OS%" == "Windows_NT" goto win9xME_args

:win9xME_args
@rem Slurp the command line arguments.
set CMD_LINE_ARGS=
set _SKIP=2

:win9xME_args_slurp
if "x%~1" == "x" goto execute

set CMD_LINE_ARGS=%*

:execute
@rem Setup the command line

set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar


@rem Execute Gradle
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %*

:end
@rem End local scope for the variables with windows NT shell
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
package com.autodesk.coroutineworker

import kotlinx.cinterop.StableRef
import kotlinx.coroutines.CancellationException
import kotlinx.coroutines.CoroutineScope
import kotlinx.coroutines.async
Expand All @@ -11,6 +10,7 @@ import kotlin.native.concurrent.AtomicReference
import kotlin.native.concurrent.SharedImmutable
import kotlin.native.concurrent.TransferMode
import kotlin.native.concurrent.Worker
import kotlin.native.concurrent.WorkerBoundReference
import kotlin.native.concurrent.ensureNeverFrozen
import kotlin.native.concurrent.freeze

Expand Down Expand Up @@ -53,15 +53,15 @@ internal class BackgroundCoroutineWorkQueueExecutor<WorkItem : CoroutineWorkItem
/**
* The wrapped (allow freezing and mutable access on single thread) queue of WorkItems
*/
private val wrappedQueue: StableRef<WorkQueue<WorkItem>> by lazy {
StableRef.create(WorkQueue<WorkItem>()).freeze()
private val wrappedQueue: WorkerBoundReference<WorkQueue<WorkItem>> by lazy {
WorkerBoundReference(WorkQueue<WorkItem>()).freeze()
}

/**
* The wrapped queue of WorkItems
*/
private val queue: WorkQueue<WorkItem>
get() = wrappedQueue.get()
get() = wrappedQueue.value

/**
* The number of workers actively processing blocks
Expand Down

0 comments on commit 1c800aa

Please sign in to comment.