Build Information
Successful build of TaskUtilities with Swift 6.0 for Linux.
Swift 6 data race errors: 5
Build Command
bash -c docker run --rm -v "checkouts-4609320-0":/host -w "$workDir" registry.gitlab.com/finestructure/spi-images:basic-6.0-latest swift build --triple x86_64-unknown-linux-gnu -Xswiftc -Xfrontend -Xswiftc -stats-output-dir -Xswiftc -Xfrontend -Xswiftc .stats -Xswiftc -strict-concurrency=complete 2>&1
Build Log
========================================
RunAll
========================================
Builder version: 4.40.0
Interrupt handler set up.
========================================
Checkout
========================================
Clone URL: https://github.com/samalone/task-utilities.git
Reference: main
Initialized empty Git repository in /host/spi-builder-workspace/.git/
hint: Using 'master' as the name for the initial branch. This default branch name
hint: is subject to change. To configure the initial branch name to use in all
hint: of your new repositories, which will suppress this warning, call:
hint:
hint: git config --global init.defaultBranch <name>
hint:
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
hint: 'development'. The just-created branch can be renamed via this command:
hint:
hint: git branch -m <name>
From https://github.com/samalone/task-utilities
* branch main -> FETCH_HEAD
* [new branch] main -> origin/main
HEAD is now at 7c6cc16 Fix README syntax
Cloned https://github.com/samalone/task-utilities.git
Revision (git rev-parse @):
7c6cc16c2bd86422a2771b133dabff69b0ddfb16
SUCCESS checkout https://github.com/samalone/task-utilities.git at main
========================================
Build
========================================
Selected platform: linux
Swift version: 6.0
Building package at path: $workDir
https://github.com/samalone/task-utilities.git
Running build ...
bash -c docker run --rm -v "checkouts-4609320-0":/host -w "$workDir" registry.gitlab.com/finestructure/spi-images:basic-6.0-latest swift build --triple x86_64-unknown-linux-gnu -Xswiftc -Xfrontend -Xswiftc -stats-output-dir -Xswiftc -Xfrontend -Xswiftc .stats -Xswiftc -strict-concurrency=complete 2>&1
Building for debugging...
[0/2] Write sources
[1/2] Write swift-version-24593BA9C3E375BF.txt
[3/6] Compiling TaskUtilities TaskPath.swift
macro expansion @TaskLocal:1:19: warning: static property '$current' is not concurrency-safe because non-'Sendable' type 'TaskLocal<TaskPath>' may have shared mutable state; this is an error in the Swift 6 language mode
`- /host/spi-builder-workspace/Sources/TaskUtilities/TaskPath.swift:22:61: note: expanded code originates here
19 | /// You can then use `TaskPath.current` to display the task
20 | /// context of the executing code.
21 | public struct TaskPath: CustomStringConvertible {
| `- note: consider making struct 'TaskPath' conform to the 'Sendable' protocol
22 | @TaskLocal public static var current: TaskPath = .init()
+--- macro expansion @TaskLocal -------------------------------------
|1 | public static let $current: TaskLocal<TaskPath> = TaskLocal(wrappedValue: .init())
| | |- warning: static property '$current' is not concurrency-safe because non-'Sendable' type 'TaskLocal<TaskPath>' may have shared mutable state; this is an error in the Swift 6 language mode
| | |- note: annotate '$current' with '@MainActor' if property should only be accessed from the main actor
| | `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
+--------------------------------------------------------------------
23 |
24 | let path: String
macro expansion @TaskLocal:1:19: warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
`- /host/spi-builder-workspace/Sources/TaskUtilities/TaskPath.swift:22:61: note: expanded code originates here
19 | /// You can then use `TaskPath.current` to display the task
20 | /// context of the executing code.
21 | public struct TaskPath: CustomStringConvertible {
| `- note: consider making struct 'TaskPath' conform to the 'Sendable' protocol
22 | @TaskLocal public static var current: TaskPath = .init()
+--- macro expansion @TaskLocal -------------------------------------
|1 | public static let $current: TaskLocal<TaskPath> = TaskLocal(wrappedValue: .init())
| | `- warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
+--------------------------------------------------------------------
23 |
24 | let path: String
macro expansion @TaskLocal:1:51: warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
`- /host/spi-builder-workspace/Sources/TaskUtilities/TaskPath.swift:22:61: note: expanded code originates here
19 | /// You can then use `TaskPath.current` to display the task
20 | /// context of the executing code.
21 | public struct TaskPath: CustomStringConvertible {
| `- note: consider making struct 'TaskPath' conform to the 'Sendable' protocol
22 | @TaskLocal public static var current: TaskPath = .init()
+--- macro expansion @TaskLocal -------------------------------------
|1 | public static let $current: TaskLocal<TaskPath> = TaskLocal(wrappedValue: .init())
| | `- warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
+--------------------------------------------------------------------
23 |
24 | let path: String
macro expansion @TaskLocal:1:51: warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
`- /host/spi-builder-workspace/Sources/TaskUtilities/TaskPath.swift:22:61: note: expanded code originates here
19 | /// You can then use `TaskPath.current` to display the task
20 | /// context of the executing code.
21 | public struct TaskPath: CustomStringConvertible {
| `- note: consider making struct 'TaskPath' conform to the 'Sendable' protocol
22 | @TaskLocal public static var current: TaskPath = .init()
+--- macro expansion @TaskLocal -------------------------------------
|1 | public static let $current: TaskLocal<TaskPath> = TaskLocal(wrappedValue: .init())
| | `- warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
+--------------------------------------------------------------------
23 |
24 | let path: String
macro expansion @TaskLocal:3:18: warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
`- /host/spi-builder-workspace/Sources/TaskUtilities/TaskPath.swift:22:61: note: expanded code originates here
19 | /// You can then use `TaskPath.current` to display the task
20 | /// context of the executing code.
21 | public struct TaskPath: CustomStringConvertible {
| `- note: consider making struct 'TaskPath' conform to the 'Sendable' protocol
22 | @TaskLocal public static var current: TaskPath = .init()
+--- macro expansion @TaskLocal -------------------------------------
|1 | {
|2 | get {
|3 | $current.get()
| | `- warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
|4 | }
|5 | }
+--------------------------------------------------------------------
23 |
24 | let path: String
/host/spi-builder-workspace/Sources/TaskUtilities/TaskPath.swift:33:35: warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
19 | /// You can then use `TaskPath.current` to display the task
20 | /// context of the executing code.
21 | public struct TaskPath: CustomStringConvertible {
| `- note: consider making struct 'TaskPath' conform to the 'Sendable' protocol
22 | @TaskLocal public static var current: TaskPath = .init()
23 |
:
31 | public static func with<R>(name: String, block: () async throws -> R) async rethrows -> R {
32 | let p = current.path
33 | return try await $current.withValue(TaskPath(path: p.isEmpty ? name : p + " > " + name), operation: block)
| `- warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
34 | }
35 |
[4/6] Compiling TaskUtilities RecursiveTaskLock.swift
/host/spi-builder-workspace/Sources/TaskUtilities/RecursiveTaskLock.swift:5:17: warning: stored property 'lock' of 'Sendable'-conforming class 'RecursiveTaskLock' has non-sendable type 'NSLock'; this is an error in the Swift 6 language mode
3 | /// A lock that can be recursively locked within the same task.
4 | public final class RecursiveTaskLock: Sendable {
5 | private let lock = NSLock()
| `- warning: stored property 'lock' of 'Sendable'-conforming class 'RecursiveTaskLock' has non-sendable type 'NSLock'; this is an error in the Swift 6 language mode
6 | @TaskLocal private static var lockedLocks: [RecursiveTaskLock] = []
7 |
Foundation.NSLock:1:12: note: class 'NSLock' does not conform to the 'Sendable' protocol
1 | open class NSLock : NSObject, NSLocking {
| `- note: class 'NSLock' does not conform to the 'Sendable' protocol
2 | override public init()
3 | deinit
/host/spi-builder-workspace/Sources/TaskUtilities/RecursiveTaskLock.swift:1:1: warning: add '@preconcurrency' to suppress 'Sendable'-related warnings from module 'Foundation'
1 | import Foundation
| `- warning: add '@preconcurrency' to suppress 'Sendable'-related warnings from module 'Foundation'
2 |
3 | /// A lock that can be recursively locked within the same task.
[5/6] Emitting module TaskUtilities
/host/spi-builder-workspace/Sources/TaskUtilities/RecursiveTaskLock.swift:5:17: warning: stored property 'lock' of 'Sendable'-conforming class 'RecursiveTaskLock' has non-sendable type 'NSLock'; this is an error in the Swift 6 language mode
3 | /// A lock that can be recursively locked within the same task.
4 | public final class RecursiveTaskLock: Sendable {
5 | private let lock = NSLock()
| `- warning: stored property 'lock' of 'Sendable'-conforming class 'RecursiveTaskLock' has non-sendable type 'NSLock'; this is an error in the Swift 6 language mode
6 | @TaskLocal private static var lockedLocks: [RecursiveTaskLock] = []
7 |
Foundation.NSLock:1:12: note: class 'NSLock' does not conform to the 'Sendable' protocol
1 | open class NSLock : NSObject, NSLocking {
| `- note: class 'NSLock' does not conform to the 'Sendable' protocol
2 | override public init()
3 | deinit
/host/spi-builder-workspace/Sources/TaskUtilities/RecursiveTaskLock.swift:1:1: warning: add '@preconcurrency' to suppress 'Sendable'-related warnings from module 'Foundation'
1 | import Foundation
| `- warning: add '@preconcurrency' to suppress 'Sendable'-related warnings from module 'Foundation'
2 |
3 | /// A lock that can be recursively locked within the same task.
macro expansion @TaskLocal:1:19: warning: static property '$current' is not concurrency-safe because non-'Sendable' type 'TaskLocal<TaskPath>' may have shared mutable state; this is an error in the Swift 6 language mode
`- /host/spi-builder-workspace/Sources/TaskUtilities/TaskPath.swift:22:61: note: expanded code originates here
19 | /// You can then use `TaskPath.current` to display the task
20 | /// context of the executing code.
21 | public struct TaskPath: CustomStringConvertible {
| `- note: consider making struct 'TaskPath' conform to the 'Sendable' protocol
22 | @TaskLocal public static var current: TaskPath = .init()
+--- macro expansion @TaskLocal -------------------------------------
|1 | public static let $current: TaskLocal<TaskPath> = TaskLocal(wrappedValue: .init())
| | |- warning: static property '$current' is not concurrency-safe because non-'Sendable' type 'TaskLocal<TaskPath>' may have shared mutable state; this is an error in the Swift 6 language mode
| | |- note: annotate '$current' with '@MainActor' if property should only be accessed from the main actor
| | `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
+--------------------------------------------------------------------
23 |
24 | let path: String
macro expansion @TaskLocal:1:19: warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
`- /host/spi-builder-workspace/Sources/TaskUtilities/TaskPath.swift:22:61: note: expanded code originates here
19 | /// You can then use `TaskPath.current` to display the task
20 | /// context of the executing code.
21 | public struct TaskPath: CustomStringConvertible {
| `- note: consider making struct 'TaskPath' conform to the 'Sendable' protocol
22 | @TaskLocal public static var current: TaskPath = .init()
+--- macro expansion @TaskLocal -------------------------------------
|1 | public static let $current: TaskLocal<TaskPath> = TaskLocal(wrappedValue: .init())
| | `- warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
+--------------------------------------------------------------------
23 |
24 | let path: String
macro expansion @TaskLocal:1:51: warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
`- /host/spi-builder-workspace/Sources/TaskUtilities/TaskPath.swift:22:61: note: expanded code originates here
19 | /// You can then use `TaskPath.current` to display the task
20 | /// context of the executing code.
21 | public struct TaskPath: CustomStringConvertible {
| `- note: consider making struct 'TaskPath' conform to the 'Sendable' protocol
22 | @TaskLocal public static var current: TaskPath = .init()
+--- macro expansion @TaskLocal -------------------------------------
|1 | public static let $current: TaskLocal<TaskPath> = TaskLocal(wrappedValue: .init())
| | `- warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
+--------------------------------------------------------------------
23 |
24 | let path: String
macro expansion @TaskLocal:1:51: warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
`- /host/spi-builder-workspace/Sources/TaskUtilities/TaskPath.swift:22:61: note: expanded code originates here
19 | /// You can then use `TaskPath.current` to display the task
20 | /// context of the executing code.
21 | public struct TaskPath: CustomStringConvertible {
| `- note: consider making struct 'TaskPath' conform to the 'Sendable' protocol
22 | @TaskLocal public static var current: TaskPath = .init()
+--- macro expansion @TaskLocal -------------------------------------
|1 | public static let $current: TaskLocal<TaskPath> = TaskLocal(wrappedValue: .init())
| | `- warning: type 'TaskPath' does not conform to the 'Sendable' protocol; this is an error in the Swift 6 language mode
+--------------------------------------------------------------------
23 |
24 | let path: String
[6/6] Compiling TaskUtilities LockedValue.swift
Build complete! (17.64s)
Build complete.
{
"dependencies" : [
],
"manifest_display_name" : "TaskUtilities",
"name" : "TaskUtilities",
"path" : "/host/spi-builder-workspace",
"platforms" : [
{
"name" : "macos",
"version" : "10.15"
},
{
"name" : "ios",
"version" : "13.0"
},
{
"name" : "watchos",
"version" : "6.0"
},
{
"name" : "tvos",
"version" : "13.0"
}
],
"products" : [
{
"name" : "TaskUtilities",
"targets" : [
"TaskUtilities"
],
"type" : {
"library" : [
"automatic"
]
}
}
],
"targets" : [
{
"c99name" : "TaskUtilitiesTests",
"module_type" : "SwiftTarget",
"name" : "TaskUtilitiesTests",
"path" : "Tests/TaskUtilitiesTests",
"sources" : [
"TaskUtilitiesTests.swift"
],
"target_dependencies" : [
"TaskUtilities"
],
"type" : "test"
},
{
"c99name" : "TaskUtilities",
"module_type" : "SwiftTarget",
"name" : "TaskUtilities",
"path" : "Sources/TaskUtilities",
"product_memberships" : [
"TaskUtilities"
],
"sources" : [
"LockedValue.swift",
"RecursiveTaskLock.swift",
"TaskPath.swift"
],
"type" : "library"
}
],
"tools_version" : "5.9"
}
Done.