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

Successful build of SwiftShell, reference master (99680b), with Swift 6.1 for Android on 27 May 2025 20:23:59 UTC.

Swift 6 data race errors: 1

Build Command

bash -c docker run --pull=always --rm -v "checkouts-4606859-2":/host -w "$PWD" registry.gitlab.com/finestructure/spi-images:android-6.1-latest swift build --swift-sdk aarch64-unknown-linux-android24 -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

Build Log

========================================
RunAll
========================================
Builder version: 4.63.1
Interrupt handler set up.
========================================
Checkout
========================================
Clone URL: https://github.com/kareman/SwiftShell.git
Reference: master
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/kareman/SwiftShell
 * branch            master     -> FETCH_HEAD
 * [new branch]      master     -> origin/master
HEAD is now at 99680b2 Release 5.1 (#95)
Cloned https://github.com/kareman/SwiftShell.git
Revision (git rev-parse @):
99680b2efc7c7dbcace1da0b3979d266f02e213c
SUCCESS checkout https://github.com/kareman/SwiftShell.git at master
========================================
Build
========================================
Selected platform:         android
Swift version:             6.1
Building package at path:  $PWD
https://github.com/kareman/SwiftShell.git
https://github.com/kareman/SwiftShell.git
WARNING: environment variable SUPPRESS_SWIFT_6_FLAGS is not set
{
  "dependencies" : [
  ],
  "manifest_display_name" : "SwiftShell",
  "name" : "SwiftShell",
  "path" : "/host/spi-builder-workspace",
  "platforms" : [
  ],
  "products" : [
    {
      "name" : "SwiftShell",
      "targets" : [
        "SwiftShell"
      ],
      "type" : {
        "library" : [
          "automatic"
        ]
      }
    }
  ],
  "swift_languages_versions" : [
    "4.2",
    "5"
  ],
  "targets" : [
    {
      "c99name" : "SwiftShellTests",
      "module_type" : "SwiftTarget",
      "name" : "SwiftShellTests",
      "path" : "Tests/SwiftShellTests",
      "sources" : [
        "Command_Tests.swift",
        "Context_Tests.swift",
        "Files_Tests.swift",
        "String_Tests.swift"
      ],
      "target_dependencies" : [
        "SwiftShell"
      ],
      "type" : "test"
    },
    {
      "c99name" : "SwiftShell",
      "module_type" : "SwiftTarget",
      "name" : "SwiftShell",
      "path" : "Sources/SwiftShell",
      "product_memberships" : [
        "SwiftShell"
      ],
      "sources" : [
        "Bash.swift",
        "Command.swift",
        "Context.swift",
        "Files.swift",
        "General/Array.swift",
        "Process.swift",
        "Stream/Lazy-split.swift",
        "Stream/Stream.swift",
        "String.swift"
      ],
      "type" : "library"
    },
    {
      "c99name" : "StreamTests",
      "module_type" : "SwiftTarget",
      "name" : "StreamTests",
      "path" : "Tests/StreamTests",
      "sources" : [
        "Collection_Tests.swift",
        "FileHandle_Tests.swift",
        "Stream_Tests.swift"
      ],
      "target_dependencies" : [
        "SwiftShell"
      ],
      "type" : "test"
    },
    {
      "c99name" : "GeneralTests",
      "module_type" : "SwiftTarget",
      "name" : "GeneralTests",
      "path" : "Tests/GeneralTests",
      "sources" : [
        "Array_Tests.swift"
      ],
      "target_dependencies" : [
        "SwiftShell"
      ],
      "type" : "test"
    }
  ],
  "tools_version" : "5.0"
}
Running build ...
bash -c docker run --pull=always --rm -v "checkouts-4606859-2":/host -w "$PWD" registry.gitlab.com/finestructure/spi-images:android-6.1-latest swift build --swift-sdk aarch64-unknown-linux-android24 -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
android-6.1-latest: Pulling from finestructure/spi-images
Digest: sha256:fe1962677657b2408c217cb5cceb3c09bc1d91486e360cebbc6eee461a5945d8
Status: Image is up to date for registry.gitlab.com/finestructure/spi-images:android-6.1-latest
Building for debugging...
[0/2] Write sources
[1/2] Write swift-version-24593BA9C3E375BF.txt
[3/11] Compiling SwiftShell Array.swift
[4/11] Compiling SwiftShell Process.swift
[5/12] Compiling SwiftShell Files.swift
[6/12] Compiling SwiftShell Context.swift
/host/spi-builder-workspace/Sources/SwiftShell/Context.swift:142:12: warning: let 'main' is not concurrency-safe because non-'Sendable' type 'MainContext' may have shared mutable state; this is an error in the Swift 6 language mode
 88 | }
 89 |
 90 | public final class MainContext: Context, CommandRunning {
    |                    `- note: class 'MainContext' does not conform to the 'Sendable' protocol
 91 | 	/// The default character encoding used throughout SwiftShell.
 92 | 	/// Only affects stdin, stdout and stderror if they have not been used yet.
    :
140 | }
141 |
142 | public let main = MainContext()
    |            |- warning: let 'main' is not concurrency-safe because non-'Sendable' type 'MainContext' may have shared mutable state; this is an error in the Swift 6 language mode
    |            |- note: add '@MainActor' to make let 'main' part of global actor 'MainActor'
    |            `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
143 |
[7/12] Emitting module SwiftShell
/host/spi-builder-workspace/Sources/SwiftShell/Context.swift:142:12: warning: let 'main' is not concurrency-safe because non-'Sendable' type 'MainContext' may have shared mutable state; this is an error in the Swift 6 language mode
 88 | }
 89 |
 90 | public final class MainContext: Context, CommandRunning {
    |                    `- note: class 'MainContext' does not conform to the 'Sendable' protocol
 91 | 	/// The default character encoding used throughout SwiftShell.
 92 | 	/// Only affects stdin, stdout and stderror if they have not been used yet.
    :
140 | }
141 |
142 | public let main = MainContext()
    |            |- warning: let 'main' is not concurrency-safe because non-'Sendable' type 'MainContext' may have shared mutable state; this is an error in the Swift 6 language mode
    |            |- note: add '@MainActor' to make let 'main' part of global actor 'MainActor'
    |            `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
143 |
[8/12] Compiling SwiftShell Bash.swift
/host/spi-builder-workspace/Sources/SwiftShell/Command.swift:151:17: warning: capture of 'command' with non-sendable type 'AsyncCommand' in a '@Sendable' closure; this is an error in the Swift 6 language mode
149 | 			if command.stdout.filehandle.fileDescriptor != command.stderror.filehandle.fileDescriptor {
150 | 				DispatchQueue.global().async(group: group) {
151 | 					stderror = command.stderror.readData()
    |                 `- warning: capture of 'command' with non-sendable type 'AsyncCommand' in a '@Sendable' closure; this is an error in the Swift 6 language mode
152 | 				}
153 | 			}
    :
334 |
335 | /** Output from the 'runAsync' commands. */
336 | public final class AsyncCommand: PrintedAsyncCommand {
    |                    `- note: class 'AsyncCommand' does not conform to the 'Sendable' protocol
337 | 	public let stdout: ReadableStream
338 | 	public let stderror: ReadableStream
/host/spi-builder-workspace/Sources/SwiftShell/Command.swift:151:6: warning: mutation of captured var 'stderror' in concurrently-executing code; this is an error in the Swift 6 language mode
149 | 			if command.stdout.filehandle.fileDescriptor != command.stderror.filehandle.fileDescriptor {
150 | 				DispatchQueue.global().async(group: group) {
151 | 					stderror = command.stderror.readData()
    |      `- warning: mutation of captured var 'stderror' in concurrently-executing code; this is an error in the Swift 6 language mode
152 | 				}
153 | 			}
/host/spi-builder-workspace/Sources/SwiftShell/Command.swift:329:4: warning: capture of 'handler' with non-sendable type '(PrintedAsyncCommand) -> Void' in a '@Sendable' closure; this is an error in the Swift 6 language mode
327 | 	@discardableResult public func onCompletion(_ handler: @escaping (PrintedAsyncCommand) -> Void) -> Self {
328 | 		process.terminationHandler = { _ in
329 | 			handler(self)
    |    |- warning: capture of 'handler' with non-sendable type '(PrintedAsyncCommand) -> 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'
330 | 		}
331 | 		return self
/host/spi-builder-workspace/Sources/SwiftShell/Command.swift:329:12: warning: capture of 'self' with non-sendable type 'Self' in a '@Sendable' closure; this is an error in the Swift 6 language mode
239 |
240 | /// Output from the `runAsyncAndPrint` commands.
241 | public class PrintedAsyncCommand {
    |              `- note: class 'PrintedAsyncCommand' does not conform to the 'Sendable' protocol
242 | 	fileprivate let process: Process
243 |
    :
327 | 	@discardableResult public func onCompletion(_ handler: @escaping (PrintedAsyncCommand) -> Void) -> Self {
328 | 		process.terminationHandler = { _ in
329 | 			handler(self)
    |            `- warning: capture of 'self' with non-sendable type 'Self' in a '@Sendable' closure; this is an error in the Swift 6 language mode
330 | 		}
331 | 		return self
/host/spi-builder-workspace/Sources/SwiftShell/Command.swift:362:4: warning: capture of 'handler' with non-sendable type '(AsyncCommand) -> Void' in a '@Sendable' closure; this is an error in the Swift 6 language mode
360 | 	@discardableResult public override func onCompletion(_ handler: @escaping (AsyncCommand) -> Void) -> Self {
361 | 		process.terminationHandler = { _ in
362 | 			handler(self)
    |    |- warning: capture of 'handler' with non-sendable type '(AsyncCommand) -> 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'
363 | 		}
364 | 		return self
/host/spi-builder-workspace/Sources/SwiftShell/Command.swift:362:12: warning: capture of 'self' with non-sendable type 'Self' in a '@Sendable' closure; this is an error in the Swift 6 language mode
334 |
335 | /** Output from the 'runAsync' commands. */
336 | public final class AsyncCommand: PrintedAsyncCommand {
    |                    `- note: class 'AsyncCommand' does not conform to the 'Sendable' protocol
337 | 	public let stdout: ReadableStream
338 | 	public let stderror: ReadableStream
    :
360 | 	@discardableResult public override func onCompletion(_ handler: @escaping (AsyncCommand) -> Void) -> Self {
361 | 		process.terminationHandler = { _ in
362 | 			handler(self)
    |            `- warning: capture of 'self' with non-sendable type 'Self' in a '@Sendable' closure; this is an error in the Swift 6 language mode
363 | 		}
364 | 		return self
[9/12] Compiling SwiftShell Command.swift
/host/spi-builder-workspace/Sources/SwiftShell/Command.swift:151:17: warning: capture of 'command' with non-sendable type 'AsyncCommand' in a '@Sendable' closure; this is an error in the Swift 6 language mode
149 | 			if command.stdout.filehandle.fileDescriptor != command.stderror.filehandle.fileDescriptor {
150 | 				DispatchQueue.global().async(group: group) {
151 | 					stderror = command.stderror.readData()
    |                 `- warning: capture of 'command' with non-sendable type 'AsyncCommand' in a '@Sendable' closure; this is an error in the Swift 6 language mode
152 | 				}
153 | 			}
    :
334 |
335 | /** Output from the 'runAsync' commands. */
336 | public final class AsyncCommand: PrintedAsyncCommand {
    |                    `- note: class 'AsyncCommand' does not conform to the 'Sendable' protocol
337 | 	public let stdout: ReadableStream
338 | 	public let stderror: ReadableStream
/host/spi-builder-workspace/Sources/SwiftShell/Command.swift:151:6: warning: mutation of captured var 'stderror' in concurrently-executing code; this is an error in the Swift 6 language mode
149 | 			if command.stdout.filehandle.fileDescriptor != command.stderror.filehandle.fileDescriptor {
150 | 				DispatchQueue.global().async(group: group) {
151 | 					stderror = command.stderror.readData()
    |      `- warning: mutation of captured var 'stderror' in concurrently-executing code; this is an error in the Swift 6 language mode
152 | 				}
153 | 			}
/host/spi-builder-workspace/Sources/SwiftShell/Command.swift:329:4: warning: capture of 'handler' with non-sendable type '(PrintedAsyncCommand) -> Void' in a '@Sendable' closure; this is an error in the Swift 6 language mode
327 | 	@discardableResult public func onCompletion(_ handler: @escaping (PrintedAsyncCommand) -> Void) -> Self {
328 | 		process.terminationHandler = { _ in
329 | 			handler(self)
    |    |- warning: capture of 'handler' with non-sendable type '(PrintedAsyncCommand) -> 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'
330 | 		}
331 | 		return self
/host/spi-builder-workspace/Sources/SwiftShell/Command.swift:329:12: warning: capture of 'self' with non-sendable type 'Self' in a '@Sendable' closure; this is an error in the Swift 6 language mode
239 |
240 | /// Output from the `runAsyncAndPrint` commands.
241 | public class PrintedAsyncCommand {
    |              `- note: class 'PrintedAsyncCommand' does not conform to the 'Sendable' protocol
242 | 	fileprivate let process: Process
243 |
    :
327 | 	@discardableResult public func onCompletion(_ handler: @escaping (PrintedAsyncCommand) -> Void) -> Self {
328 | 		process.terminationHandler = { _ in
329 | 			handler(self)
    |            `- warning: capture of 'self' with non-sendable type 'Self' in a '@Sendable' closure; this is an error in the Swift 6 language mode
330 | 		}
331 | 		return self
/host/spi-builder-workspace/Sources/SwiftShell/Command.swift:362:4: warning: capture of 'handler' with non-sendable type '(AsyncCommand) -> Void' in a '@Sendable' closure; this is an error in the Swift 6 language mode
360 | 	@discardableResult public override func onCompletion(_ handler: @escaping (AsyncCommand) -> Void) -> Self {
361 | 		process.terminationHandler = { _ in
362 | 			handler(self)
    |    |- warning: capture of 'handler' with non-sendable type '(AsyncCommand) -> 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'
363 | 		}
364 | 		return self
/host/spi-builder-workspace/Sources/SwiftShell/Command.swift:362:12: warning: capture of 'self' with non-sendable type 'Self' in a '@Sendable' closure; this is an error in the Swift 6 language mode
334 |
335 | /** Output from the 'runAsync' commands. */
336 | public final class AsyncCommand: PrintedAsyncCommand {
    |                    `- note: class 'AsyncCommand' does not conform to the 'Sendable' protocol
337 | 	public let stdout: ReadableStream
338 | 	public let stderror: ReadableStream
    :
360 | 	@discardableResult public override func onCompletion(_ handler: @escaping (AsyncCommand) -> Void) -> Self {
361 | 		process.terminationHandler = { _ in
362 | 			handler(self)
    |            `- warning: capture of 'self' with non-sendable type 'Self' in a '@Sendable' closure; this is an error in the Swift 6 language mode
363 | 		}
364 | 		return self
[10/12] Compiling SwiftShell Lazy-split.swift
[11/12] Compiling SwiftShell Stream.swift
/host/spi-builder-workspace/Sources/SwiftShell/Stream/Stream.swift:113:4: warning: capture of 'self' with non-sendable type 'Self?' in a '@Sendable' closure; this is an error in the Swift 6 language mode
111 | 	public func onOutput(_ handler: @escaping (ReadableStream) -> Void) {
112 | 		filehandle.readabilityHandler = { [weak self] _ in
113 | 			self.map(handler)
    |    `- warning: capture of 'self' with non-sendable type 'Self?' in a '@Sendable' closure; this is an error in the Swift 6 language mode
114 | 		}
115 | 	}
SwiftShell.ReadableStream.Self:2:1: note: consider making generic parameter 'Self' conform to the 'Sendable' protocol
1 | protocol ReadableStream {
2 | Self : SwiftShell.ReadableStream}
  | `- note: consider making generic parameter 'Self' conform to the 'Sendable' protocol
3 |
/host/spi-builder-workspace/Sources/SwiftShell/Stream/Stream.swift:113:13: warning: capture of 'handler' with non-sendable type '(any ReadableStream) -> Void' in a '@Sendable' closure; this is an error in the Swift 6 language mode
111 | 	public func onOutput(_ handler: @escaping (ReadableStream) -> Void) {
112 | 		filehandle.readabilityHandler = { [weak self] _ in
113 | 			self.map(handler)
    |             |- warning: capture of 'handler' with non-sendable type '(any ReadableStream) -> 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'
114 | 		}
115 | 	}
[12/12] Compiling SwiftShell String.swift
Build complete! (13.01s)
Build complete.
{
  "dependencies" : [
  ],
  "manifest_display_name" : "SwiftShell",
  "name" : "SwiftShell",
  "path" : "/host/spi-builder-workspace",
  "platforms" : [
  ],
  "products" : [
    {
      "name" : "SwiftShell",
      "targets" : [
        "SwiftShell"
      ],
      "type" : {
        "library" : [
          "automatic"
        ]
      }
    }
  ],
  "swift_languages_versions" : [
    "4.2",
    "5"
  ],
  "targets" : [
    {
      "c99name" : "SwiftShellTests",
      "module_type" : "SwiftTarget",
      "name" : "SwiftShellTests",
      "path" : "Tests/SwiftShellTests",
      "sources" : [
        "Command_Tests.swift",
        "Context_Tests.swift",
        "Files_Tests.swift",
        "String_Tests.swift"
      ],
      "target_dependencies" : [
        "SwiftShell"
      ],
      "type" : "test"
    },
    {
      "c99name" : "SwiftShell",
      "module_type" : "SwiftTarget",
      "name" : "SwiftShell",
      "path" : "Sources/SwiftShell",
      "product_memberships" : [
        "SwiftShell"
      ],
      "sources" : [
        "Bash.swift",
        "Command.swift",
        "Context.swift",
        "Files.swift",
        "General/Array.swift",
        "Process.swift",
        "Stream/Lazy-split.swift",
        "Stream/Stream.swift",
        "String.swift"
      ],
      "type" : "library"
    },
    {
      "c99name" : "StreamTests",
      "module_type" : "SwiftTarget",
      "name" : "StreamTests",
      "path" : "Tests/StreamTests",
      "sources" : [
        "Collection_Tests.swift",
        "FileHandle_Tests.swift",
        "Stream_Tests.swift"
      ],
      "target_dependencies" : [
        "SwiftShell"
      ],
      "type" : "test"
    },
    {
      "c99name" : "GeneralTests",
      "module_type" : "SwiftTarget",
      "name" : "GeneralTests",
      "path" : "Tests/GeneralTests",
      "sources" : [
        "Array_Tests.swift"
      ],
      "target_dependencies" : [
        "SwiftShell"
      ],
      "type" : "test"
    }
  ],
  "tools_version" : "5.0"
}
android-6.1-latest: Pulling from finestructure/spi-images
Digest: sha256:fe1962677657b2408c217cb5cceb3c09bc1d91486e360cebbc6eee461a5945d8
Status: Image is up to date for registry.gitlab.com/finestructure/spi-images:android-6.1-latest
Done.