The Swift Package Index logo.Swift Package Index

Has it really been five years since Swift Package Index launched? Read our anniversary blog post!

Build Information

Failed to build Disposable, reference main (0f81e7), with Swift 6.1 for Wasm on 28 May 2025 17:02:32 UTC.

Build Command

bash -c docker run --pull=always --rm -v "checkouts-4609320-1":/host -w "$PWD" registry.gitlab.com/finestructure/spi-images:wasm-6.1-latest swift build --swift-sdk wasm32-unknown-wasi 2>&1

Build Log

========================================
RunAll
========================================
Builder version: 4.63.1
Interrupt handler set up.
========================================
Checkout
========================================
Clone URL: https://github.com/GoodHatsLLC/Disposable.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/GoodHatsLLC/Disposable
 * branch            main       -> FETCH_HEAD
 * [new branch]      main       -> origin/main
HEAD is now at 0f81e7e update documentation and swift version syntax
Cloned https://github.com/GoodHatsLLC/Disposable.git
Revision (git rev-parse @):
0f81e7e98b832ac0390976e398b3e76f3c1ede5d
SUCCESS checkout https://github.com/GoodHatsLLC/Disposable.git at main
========================================
Build
========================================
Selected platform:         wasm
Swift version:             6.1
Building package at path:  $PWD
https://github.com/GoodHatsLLC/Disposable.git
https://github.com/GoodHatsLLC/Disposable.git
WARNING: environment variable SUPPRESS_SWIFT_6_FLAGS is not set
{
  "dependencies" : [
  ],
  "manifest_display_name" : "Disposable",
  "name" : "Disposable",
  "path" : "/host/spi-builder-workspace",
  "platforms" : [
    {
      "name" : "macos",
      "version" : "12.3"
    },
    {
      "name" : "ios",
      "version" : "15.4"
    },
    {
      "name" : "tvos",
      "version" : "15.4"
    },
    {
      "name" : "watchos",
      "version" : "8.5"
    },
    {
      "name" : "maccatalyst",
      "version" : "15.4"
    }
  ],
  "products" : [
    {
      "name" : "Disposable",
      "targets" : [
        "Disposable"
      ],
      "type" : {
        "library" : [
          "automatic"
        ]
      }
    }
  ],
  "targets" : [
    {
      "c99name" : "DisposableTests",
      "module_type" : "SwiftTarget",
      "name" : "DisposableTests",
      "path" : "Tests/DisposableTests",
      "sources" : [
        "AutoDisposeable.swift",
        "BasicTests.swift",
        "CombineBridgeTests.swift",
        "ConvenienceStageTests.swift",
        "DisposalStageTests.swift",
        "TaskBridgeTests.swift",
        "ThreadingTests.swift"
      ],
      "target_dependencies" : [
        "Disposable"
      ],
      "type" : "test"
    },
    {
      "c99name" : "Disposable",
      "module_type" : "SwiftTarget",
      "name" : "Disposable",
      "path" : "Sources/Disposable",
      "product_memberships" : [
        "Disposable"
      ],
      "sources" : [
        "AutoDisposable.swift",
        "Bridging/CombineExtensions.swift",
        "Bridging/TaskExtensions.swift",
        "ConvenienceStages.swift",
        "Disposable.swift",
        "DisposableBuilder.swift",
        "DisposableStage.swift",
        "ErasedDisposable.swift",
        "Locked.swift",
        "Task.swift"
      ],
      "type" : "library"
    }
  ],
  "tools_version" : "5.8"
}
Running build ...
bash -c docker run --pull=always --rm -v "checkouts-4609320-1":/host -w "$PWD" registry.gitlab.com/finestructure/spi-images:wasm-6.1-latest swift build --swift-sdk wasm32-unknown-wasi -Xswiftc -Xfrontend -Xswiftc -stats-output-dir -Xswiftc -Xfrontend -Xswiftc .stats -Xswiftc -strict-concurrency=complete -Xswiftc -enable-upcoming-feature -Xswiftc StrictConcurrency -Xswiftc -enable-upcoming-feature -Xswiftc DisableOutwardActorInference -Xswiftc -enable-upcoming-feature -Xswiftc GlobalActorIsolatedTypesUsability -Xswiftc -enable-upcoming-feature -Xswiftc InferSendableFromCaptures 2>&1
wasm-6.1-latest: Pulling from finestructure/spi-images
Digest: sha256:7e37457820e5f17452a98118754f345f2619722c485f2db0d8b666940a83afd2
Status: Image is up to date for registry.gitlab.com/finestructure/spi-images:wasm-6.1-latest
Building for debugging...
[0/2] Write sources
[1/2] Write swift-version-24593BA9C3E375BF.txt
[3/12] Emitting module Disposable
/host/spi-builder-workspace/Sources/Disposable/ConvenienceStages.swift:65:26: warning: static property 'identifiedStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 63 |
 64 |   fileprivate static let indefinite = DisposableStage()
 65 |   fileprivate static var identifiedStage = Locked([String: any Disposable]())
    |                          |- warning: static property 'identifiedStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                          |- note: convert 'identifiedStage' to a 'let' constant to make 'Sendable' shared state immutable
    |                          |- note: add '@MainActor' to make static property 'identifiedStage' part of global actor 'MainActor'
    |                          `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 66 |   fileprivate static var callSiteStage = Locked([String: any Disposable]())
 67 |
/host/spi-builder-workspace/Sources/Disposable/ConvenienceStages.swift:66:26: warning: static property 'callSiteStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 64 |   fileprivate static let indefinite = DisposableStage()
 65 |   fileprivate static var identifiedStage = Locked([String: any Disposable]())
 66 |   fileprivate static var callSiteStage = Locked([String: any Disposable]())
    |                          |- warning: static property 'callSiteStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                          |- note: convert 'callSiteStage' to a 'let' constant to make 'Sendable' shared state immutable
    |                          |- note: add '@MainActor' to make static property 'callSiteStage' part of global actor 'MainActor'
    |                          `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 67 |
 68 | }
[4/13] Compiling Disposable Disposable.swift
[5/13] Compiling Disposable Task.swift
[6/13] Compiling Disposable AutoDisposable.swift
[7/13] Compiling Disposable CombineExtensions.swift
[8/13] Compiling Disposable TaskExtensions.swift
/host/spi-builder-workspace/Sources/Disposable/ConvenienceStages.swift:65:26: warning: static property 'identifiedStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 63 |
 64 |   fileprivate static let indefinite = DisposableStage()
 65 |   fileprivate static var identifiedStage = Locked([String: any Disposable]())
    |                          |- warning: static property 'identifiedStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                          |- note: convert 'identifiedStage' to a 'let' constant to make 'Sendable' shared state immutable
    |                          |- note: add '@MainActor' to make static property 'identifiedStage' part of global actor 'MainActor'
    |                          `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 66 |   fileprivate static var callSiteStage = Locked([String: any Disposable]())
 67 |
/host/spi-builder-workspace/Sources/Disposable/ConvenienceStages.swift:66:26: warning: static property 'callSiteStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 64 |   fileprivate static let indefinite = DisposableStage()
 65 |   fileprivate static var identifiedStage = Locked([String: any Disposable]())
 66 |   fileprivate static var callSiteStage = Locked([String: any Disposable]())
    |                          |- warning: static property 'callSiteStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                          |- note: convert 'callSiteStage' to a 'let' constant to make 'Sendable' shared state immutable
    |                          |- note: add '@MainActor' to make static property 'callSiteStage' part of global actor 'MainActor'
    |                          `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 67 |
 68 | }
[9/13] Compiling Disposable ConvenienceStages.swift
/host/spi-builder-workspace/Sources/Disposable/ConvenienceStages.swift:65:26: warning: static property 'identifiedStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 63 |
 64 |   fileprivate static let indefinite = DisposableStage()
 65 |   fileprivate static var identifiedStage = Locked([String: any Disposable]())
    |                          |- warning: static property 'identifiedStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                          |- note: convert 'identifiedStage' to a 'let' constant to make 'Sendable' shared state immutable
    |                          |- note: add '@MainActor' to make static property 'identifiedStage' part of global actor 'MainActor'
    |                          `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 66 |   fileprivate static var callSiteStage = Locked([String: any Disposable]())
 67 |
/host/spi-builder-workspace/Sources/Disposable/ConvenienceStages.swift:66:26: warning: static property 'callSiteStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 64 |   fileprivate static let indefinite = DisposableStage()
 65 |   fileprivate static var identifiedStage = Locked([String: any Disposable]())
 66 |   fileprivate static var callSiteStage = Locked([String: any Disposable]())
    |                          |- warning: static property 'callSiteStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                          |- note: convert 'callSiteStage' to a 'let' constant to make 'Sendable' shared state immutable
    |                          |- note: add '@MainActor' to make static property 'callSiteStage' part of global actor 'MainActor'
    |                          `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 67 |
 68 | }
[10/13] Compiling Disposable ErasedDisposable.swift
/host/spi-builder-workspace/Sources/Disposable/ErasedDisposable.swift:21:43: warning: capture of 'disposal' with non-sendable type '() -> Void' in a '@Sendable' closure; this is an error in the Swift 6 language mode
19 |
20 |   public nonisolated init(disposal: @escaping () -> Void) {
21 |     self.disposalAction = Locked(Action { disposal() })
   |                                           |- warning: capture of 'disposal' with non-sendable type '() -> Void' in a '@Sendable' closure; this is an error in the Swift 6 language mode
   |                                           `- note: a function type must be marked '@Sendable' to conform to 'Sendable'
22 |     self.id = .init()
23 |   }
[11/13] Compiling Disposable DisposableStage.swift
[12/13] Compiling Disposable DisposableBuilder.swift
[13/13] Compiling Disposable Locked.swift
/host/spi-builder-workspace/Sources/Disposable/Locked.swift:223:5: error: cannot find 'pthread_mutex_lock' in scope
221 |   @inline(__always)
222 |   fileprivate func lock() {
223 |     pthread_mutex_lock(&mutex)
    |     `- error: cannot find 'pthread_mutex_lock' in scope
224 |   }
225 |
/host/spi-builder-workspace/Sources/Disposable/Locked.swift:228:5: error: cannot find 'pthread_mutex_unlock' in scope
226 |   @inline(__always)
227 |   fileprivate func unlock() {
228 |     pthread_mutex_unlock(&mutex)
    |     `- error: cannot find 'pthread_mutex_unlock' in scope
229 |   }
230 |
Running build ...
bash -c docker run --pull=always --rm -v "checkouts-4609320-1":/host -w "$PWD" registry.gitlab.com/finestructure/spi-images:wasm-6.1-latest swift build --swift-sdk wasm32-unknown-wasi 2>&1
wasm-6.1-latest: Pulling from finestructure/spi-images
Digest: sha256:7e37457820e5f17452a98118754f345f2619722c485f2db0d8b666940a83afd2
Status: Image is up to date for registry.gitlab.com/finestructure/spi-images:wasm-6.1-latest
[0/1] Planning build
Building for debugging...
[0/1] Write swift-version-24593BA9C3E375BF.txt
[2/11] Compiling Disposable Locked.swift
/host/spi-builder-workspace/Sources/Disposable/Locked.swift:223:5: error: cannot find 'pthread_mutex_lock' in scope
221 |   @inline(__always)
222 |   fileprivate func lock() {
223 |     pthread_mutex_lock(&mutex)
    |     `- error: cannot find 'pthread_mutex_lock' in scope
224 |   }
225 |
/host/spi-builder-workspace/Sources/Disposable/Locked.swift:228:5: error: cannot find 'pthread_mutex_unlock' in scope
226 |   @inline(__always)
227 |   fileprivate func unlock() {
228 |     pthread_mutex_unlock(&mutex)
    |     `- error: cannot find 'pthread_mutex_unlock' in scope
229 |   }
230 |
[3/12] Compiling Disposable ErasedDisposable.swift
/host/spi-builder-workspace/Sources/Disposable/ErasedDisposable.swift:21:43: warning: capture of 'disposal' with non-sendable type '() -> Void' in a '@Sendable' closure; this is an error in the Swift 6 language mode
19 |
20 |   public nonisolated init(disposal: @escaping () -> Void) {
21 |     self.disposalAction = Locked(Action { disposal() })
   |                                           |- warning: capture of 'disposal' with non-sendable type '() -> Void' in a '@Sendable' closure; this is an error in the Swift 6 language mode
   |                                           `- note: a function type must be marked '@Sendable' to conform to 'Sendable'
22 |     self.id = .init()
23 |   }
[4/12] Compiling Disposable DisposableStage.swift
[5/12] Compiling Disposable TaskExtensions.swift
/host/spi-builder-workspace/Sources/Disposable/ConvenienceStages.swift:65:26: warning: static property 'identifiedStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 63 |
 64 |   fileprivate static let indefinite = DisposableStage()
 65 |   fileprivate static var identifiedStage = Locked([String: any Disposable]())
    |                          |- warning: static property 'identifiedStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                          |- note: convert 'identifiedStage' to a 'let' constant to make 'Sendable' shared state immutable
    |                          |- note: add '@MainActor' to make static property 'identifiedStage' part of global actor 'MainActor'
    |                          `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 66 |   fileprivate static var callSiteStage = Locked([String: any Disposable]())
 67 |
/host/spi-builder-workspace/Sources/Disposable/ConvenienceStages.swift:66:26: warning: static property 'callSiteStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 64 |   fileprivate static let indefinite = DisposableStage()
 65 |   fileprivate static var identifiedStage = Locked([String: any Disposable]())
 66 |   fileprivate static var callSiteStage = Locked([String: any Disposable]())
    |                          |- warning: static property 'callSiteStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                          |- note: convert 'callSiteStage' to a 'let' constant to make 'Sendable' shared state immutable
    |                          |- note: add '@MainActor' to make static property 'callSiteStage' part of global actor 'MainActor'
    |                          `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 67 |
 68 | }
[6/12] Compiling Disposable ConvenienceStages.swift
/host/spi-builder-workspace/Sources/Disposable/ConvenienceStages.swift:65:26: warning: static property 'identifiedStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 63 |
 64 |   fileprivate static let indefinite = DisposableStage()
 65 |   fileprivate static var identifiedStage = Locked([String: any Disposable]())
    |                          |- warning: static property 'identifiedStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                          |- note: convert 'identifiedStage' to a 'let' constant to make 'Sendable' shared state immutable
    |                          |- note: add '@MainActor' to make static property 'identifiedStage' part of global actor 'MainActor'
    |                          `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 66 |   fileprivate static var callSiteStage = Locked([String: any Disposable]())
 67 |
/host/spi-builder-workspace/Sources/Disposable/ConvenienceStages.swift:66:26: warning: static property 'callSiteStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 64 |   fileprivate static let indefinite = DisposableStage()
 65 |   fileprivate static var identifiedStage = Locked([String: any Disposable]())
 66 |   fileprivate static var callSiteStage = Locked([String: any Disposable]())
    |                          |- warning: static property 'callSiteStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                          |- note: convert 'callSiteStage' to a 'let' constant to make 'Sendable' shared state immutable
    |                          |- note: add '@MainActor' to make static property 'callSiteStage' part of global actor 'MainActor'
    |                          `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 67 |
 68 | }
[7/12] Compiling Disposable DisposableBuilder.swift
[8/12] Compiling Disposable Disposable.swift
[9/12] Emitting module Disposable
/host/spi-builder-workspace/Sources/Disposable/ConvenienceStages.swift:65:26: warning: static property 'identifiedStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 63 |
 64 |   fileprivate static let indefinite = DisposableStage()
 65 |   fileprivate static var identifiedStage = Locked([String: any Disposable]())
    |                          |- warning: static property 'identifiedStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                          |- note: convert 'identifiedStage' to a 'let' constant to make 'Sendable' shared state immutable
    |                          |- note: add '@MainActor' to make static property 'identifiedStage' part of global actor 'MainActor'
    |                          `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 66 |   fileprivate static var callSiteStage = Locked([String: any Disposable]())
 67 |
/host/spi-builder-workspace/Sources/Disposable/ConvenienceStages.swift:66:26: warning: static property 'callSiteStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 64 |   fileprivate static let indefinite = DisposableStage()
 65 |   fileprivate static var identifiedStage = Locked([String: any Disposable]())
 66 |   fileprivate static var callSiteStage = Locked([String: any Disposable]())
    |                          |- warning: static property 'callSiteStage' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                          |- note: convert 'callSiteStage' to a 'let' constant to make 'Sendable' shared state immutable
    |                          |- note: add '@MainActor' to make static property 'callSiteStage' part of global actor 'MainActor'
    |                          `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 67 |
 68 | }
[10/12] Compiling Disposable AutoDisposable.swift
[11/12] Compiling Disposable CombineExtensions.swift
[12/12] Compiling Disposable Task.swift
BUILD FAILURE 6.1 wasm