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 macOS (SPM) on 26 Apr 2025 03:25:03 UTC.

Swift 6 data race errors: 2

Build Command

env DEVELOPER_DIR=/Applications/Xcode-16.3.0.app xcrun swift build --arch arm64 -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

Build Log

========================================
RunAll
========================================
Builder version: 4.61.0
Interrupt handler set up.
========================================
Checkout
========================================
Clone URL: https://github.com/kareman/SwiftShell.git
Reference: master
Initialized empty Git repository in /Users/admin/builder/spi-builder-workspace/.git/
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
========================================
ResolveProductDependencies
========================================
Resolving dependencies ...
{
  "identity": ".resolve-product-dependencies",
  "name": "resolve-dependencies",
  "url": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies",
  "version": "unspecified",
  "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies",
  "dependencies": [
    {
      "identity": "swiftshell",
      "name": "SwiftShell",
      "url": "https://github.com/kareman/SwiftShell.git",
      "version": "unspecified",
      "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/SwiftShell",
      "dependencies": [
      ]
    }
  ]
}
Fetching https://github.com/kareman/SwiftShell.git
[1/4863] Fetching swiftshell
Fetched https://github.com/kareman/SwiftShell.git from cache (1.19s)
Creating working copy for https://github.com/kareman/SwiftShell.git
Working copy of https://github.com/kareman/SwiftShell.git resolved at master (99680b2)
warning: '.resolve-product-dependencies': dependency 'swiftshell' is not used by any target
Found 0 product dependencies
========================================
Build
========================================
Selected platform:         macosSpm
Swift version:             6.1
Building package at path:  $PWD
https://github.com/kareman/SwiftShell.git
https://github.com/kareman/SwiftShell.git
{
  "dependencies" : [
  ],
  "manifest_display_name" : "SwiftShell",
  "name" : "SwiftShell",
  "path" : "/Users/admin/builder/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 ...
env DEVELOPER_DIR=/Applications/Xcode-16.3.0.app xcrun swift build --arch arm64 -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
Building for debugging...
[0/2] Write sources
[1/2] Write swift-version-2F0A5646E1D333AE.txt
[3/12] Emitting module SwiftShell
/Users/admin/builder/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 |
/Users/admin/builder/spi-builder-workspace/Sources/SwiftShell/Files.swift:11:12: warning: let 'Files' is not concurrency-safe because non-'Sendable' type 'FileManager' may have shared mutable state; this is an error in the Swift 6 language mode
 9 |
10 | /** The default FileManager */
11 | public let Files = FileManager.default
   |            |- warning: let 'Files' is not concurrency-safe because non-'Sendable' type 'FileManager' may have shared mutable state; this is an error in the Swift 6 language mode
   |            |- note: add '@MainActor' to make let 'Files' part of global actor 'MainActor'
   |            `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
12 |
13 | /** Appends file or directory url to directory url */
/Applications/Xcode-16.3.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX15.4.sdk/System/Library/Frameworks/Foundation.framework/Headers/NSFileManager.h:96:12: note: class 'FileManager' does not conform to the 'Sendable' protocol
 94 | extern NSNotificationName const NSUbiquityIdentityDidChangeNotification API_AVAILABLE(macos(10.8), ios(6.0), watchos(2.0), tvos(9.0));
 95 |
 96 | @interface NSFileManager : NSObject
    |            `- note: class 'FileManager' does not conform to the 'Sendable' protocol
 97 |
 98 | /* Returns the default singleton instance.
[4/12] Compiling SwiftShell String.swift
[5/12] Compiling SwiftShell Command.swift
/Users/admin/builder/spi-builder-workspace/Sources/SwiftShell/Command.swift:151:17: warning: capture of 'command' with non-sendable type 'AsyncCommand' in a '@Sendable' closure
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
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
/Users/admin/builder/spi-builder-workspace/Sources/SwiftShell/Command.swift:151:6: warning: mutation of captured var 'stderror' in concurrently-executing code
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
152 | 				}
153 | 			}
/Users/admin/builder/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
/Users/admin/builder/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
/Users/admin/builder/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
/Users/admin/builder/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
[6/12] Compiling SwiftShell Bash.swift
[7/12] Compiling SwiftShell Files.swift
/Users/admin/builder/spi-builder-workspace/Sources/SwiftShell/Files.swift:11:12: warning: let 'Files' is not concurrency-safe because non-'Sendable' type 'FileManager' may have shared mutable state; this is an error in the Swift 6 language mode
 9 |
10 | /** The default FileManager */
11 | public let Files = FileManager.default
   |            |- warning: let 'Files' is not concurrency-safe because non-'Sendable' type 'FileManager' may have shared mutable state; this is an error in the Swift 6 language mode
   |            |- note: add '@MainActor' to make let 'Files' part of global actor 'MainActor'
   |            `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
12 |
13 | /** Appends file or directory url to directory url */
/Applications/Xcode-16.3.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX15.4.sdk/System/Library/Frameworks/Foundation.framework/Headers/NSFileManager.h:96:12: note: class 'FileManager' does not conform to the 'Sendable' protocol
 94 | extern NSNotificationName const NSUbiquityIdentityDidChangeNotification API_AVAILABLE(macos(10.8), ios(6.0), watchos(2.0), tvos(9.0));
 95 |
 96 | @interface NSFileManager : NSObject
    |            `- note: class 'FileManager' does not conform to the 'Sendable' protocol
 97 |
 98 | /* Returns the default singleton instance.
[8/12] Compiling SwiftShell Context.swift
/Users/admin/builder/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 |
[9/12] Compiling SwiftShell Array.swift
[10/12] Compiling SwiftShell Lazy-split.swift
[11/12] Compiling SwiftShell Stream.swift
/Users/admin/builder/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 |
/Users/admin/builder/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 Process.swift
Build complete! (5.21s)
Build complete.
{
  "dependencies" : [
  ],
  "manifest_display_name" : "SwiftShell",
  "name" : "SwiftShell",
  "path" : "/Users/admin/builder/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"
}
Done.