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 Rainbow, reference master (16da5c), with Swift 6.1 for Linux on 26 Jul 2025 09:55:56 UTC.

Swift 6 data race errors: 5

Build Command

bash -c docker run --pull=always --rm -v "checkouts-4609320-0":/host -w "$PWD" registry.gitlab.com/finestructure/spi-images:basic-6.1-latest swift build --triple x86_64-unknown-linux-gnu -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.64.0
Interrupt handler set up.
========================================
Checkout
========================================
Clone URL: https://github.com/onevcat/Rainbow.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/onevcat/Rainbow
 * branch            master     -> FETCH_HEAD
 * [new branch]      master     -> origin/master
HEAD is now at 16da5c6 Bump version to 4.2.0
Cloned https://github.com/onevcat/Rainbow.git
Revision (git rev-parse @):
16da5c62dd737258c6df2e8c430f8a3202f655a7
SUCCESS checkout https://github.com/onevcat/Rainbow.git at master
========================================
Build
========================================
Selected platform:         linux
Swift version:             6.1
Building package at path:  $PWD
https://github.com/onevcat/Rainbow.git
https://github.com/onevcat/Rainbow.git
WARNING: environment variable SUPPRESS_SWIFT_6_FLAGS is not set
{
  "dependencies" : [
  ],
  "manifest_display_name" : "Rainbow",
  "name" : "Rainbow",
  "path" : "/host/spi-builder-workspace",
  "platforms" : [
  ],
  "products" : [
    {
      "name" : "Rainbow",
      "targets" : [
        "Rainbow"
      ],
      "type" : {
        "library" : [
          "automatic"
        ]
      }
    },
    {
      "name" : "RainbowPlayground",
      "targets" : [
        "RainbowPlayground"
      ],
      "type" : {
        "executable" : null
      }
    }
  ],
  "targets" : [
    {
      "c99name" : "RainbowTests",
      "module_type" : "SwiftTarget",
      "name" : "RainbowTests",
      "path" : "Tests",
      "sources" : [
        "RainbowTests/ColorApproximatedTests.swift",
        "RainbowTests/ColorTests.swift",
        "RainbowTests/ConditionalStylingTests.swift",
        "RainbowTests/ConsoleStringTests.swift",
        "RainbowTests/ConsoleTextParserTests.swift",
        "RainbowTests/EdgeCaseTests.swift",
        "RainbowTests/HSLColorTests.swift",
        "RainbowTests/PerformanceTests.swift",
        "RainbowTests/RainbowTests.swift",
        "RainbowTests/StyledStringBuilderTests.swift"
      ],
      "target_dependencies" : [
        "Rainbow"
      ],
      "type" : "test"
    },
    {
      "c99name" : "RainbowPlayground",
      "module_type" : "SwiftTarget",
      "name" : "RainbowPlayground",
      "path" : "Playground",
      "product_memberships" : [
        "RainbowPlayground"
      ],
      "sources" : [
        "main.swift"
      ],
      "target_dependencies" : [
        "Rainbow"
      ],
      "type" : "executable"
    },
    {
      "c99name" : "Rainbow",
      "module_type" : "SwiftTarget",
      "name" : "Rainbow",
      "path" : "Sources",
      "product_memberships" : [
        "Rainbow",
        "RainbowPlayground"
      ],
      "sources" : [
        "BackgroundColor.swift",
        "CodesParser.swift",
        "Color.swift",
        "ColorApproximation.swift",
        "ConditionalStyleBuilder.swift",
        "ControlCode.swift",
        "HSLColorConverter.swift",
        "ModesExtractor.swift",
        "OutputTarget.swift",
        "Rainbow.swift",
        "String+ConditionalStyling.swift",
        "String+Rainbow.swift",
        "StringGenerator.swift",
        "Style.swift",
        "StyledStringBuilder.swift"
      ],
      "type" : "library"
    }
  ],
  "tools_version" : "4.0"
}
Running build ...
bash -c docker run --pull=always --rm -v "checkouts-4609320-0":/host -w "$PWD" registry.gitlab.com/finestructure/spi-images:basic-6.1-latest swift build --triple x86_64-unknown-linux-gnu -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
basic-6.1-latest: Pulling from finestructure/spi-images
Digest: sha256:2e2b3aca8600f890617c2faa770b70e33c1dfd303d6f92b308423b89ef6bde64
Status: Image is up to date for registry.gitlab.com/finestructure/spi-images:basic-6.1-latest
Building for debugging...
[0/7] Write sources
[2/7] Write swift-version-24593BA9C3E375BF.txt
[4/22] Compiling Rainbow StringGenerator.swift
[5/22] Compiling Rainbow Style.swift
[6/23] Compiling Rainbow String+ConditionalStyling.swift
[7/23] Compiling Rainbow String+Rainbow.swift
[8/23] Compiling Rainbow BackgroundColor.swift
[9/23] Compiling Rainbow CodesParser.swift
[10/23] Compiling Rainbow Color.swift
[11/23] Compiling Rainbow ColorApproximation.swift
[12/23] Emitting module Rainbow
/host/spi-builder-workspace/Sources/OutputTarget.swift:46:16: warning: static property 'current' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
44 |
45 |     /// Detected output target by current environment.
46 |     static var current: OutputTarget = {
   |                |- warning: static property 'current' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
   |                |- note: convert 'current' to a 'let' constant to make 'Sendable' shared state immutable
   |                |- note: add '@MainActor' to make static property 'current' part of global actor 'MainActor'
   |                `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
47 |         // Check if we are in any term env and the output is a tty.
48 |         let termType = getEnvValue("TERM")
/host/spi-builder-workspace/Sources/OutputTarget.swift:49:72: warning: reference to var 'stdout' is not concurrency-safe because it involves shared mutable state; this is an error in the Swift 6 language mode
47 |         // Check if we are in any term env and the output is a tty.
48 |         let termType = getEnvValue("TERM")
49 |         if let t = termType, t.lowercased() != "dumb" && isatty(fileno(stdout)) != 0 {
   |                                                                        `- warning: reference to var 'stdout' is not concurrency-safe because it involves shared mutable state; this is an error in the Swift 6 language mode
50 |             return .console
51 |         }
/usr/include/stdio.h:144:14: note: var declared here
142 | /* Standard streams.  */
143 | extern FILE *stdin;		/* Standard input stream.  */
144 | extern FILE *stdout;		/* Standard output stream.  */
    |              `- note: var declared here
145 | extern FILE *stderr;		/* Standard error output stream.  */
146 | /* C89/C99 say they're macros.  Make them happy.  */
/host/spi-builder-workspace/Sources/Rainbow.swift:98:23: warning: static property 'outputTarget' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 96 |     /// Output target for `Rainbow`. `Rainbow` should detect correct target itself, so you rarely need to set it.
 97 |     /// However, if you want the colorized string to be different, or the detection is not correct, you can set it manually.
 98 |     public static var outputTarget = OutputTarget.current
    |                       |- warning: static property 'outputTarget' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                       |- note: convert 'outputTarget' to a 'let' constant to make 'Sendable' shared state immutable
    |                       |- note: add '@MainActor' to make static property 'outputTarget' part of global actor 'MainActor'
    |                       `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 99 |
100 |     static var environment = ProcessInfo.processInfo.environment
/host/spi-builder-workspace/Sources/Rainbow.swift:100:16: warning: static property 'environment' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 98 |     public static var outputTarget = OutputTarget.current
 99 |
100 |     static var environment = ProcessInfo.processInfo.environment
    |                |- warning: static property 'environment' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                |- note: convert 'environment' to a 'let' constant to make 'Sendable' shared state immutable
    |                |- note: add '@MainActor' to make static property 'environment' part of global actor 'MainActor'
    |                `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
101 |     static func hasValidValueInEnvironment(_ key: String) -> Bool {
102 |         guard !key.isEmpty, let value = environment[key] else {
/host/spi-builder-workspace/Sources/Rainbow.swift:121:23: warning: static property 'enabled' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
119 |     /// set and `FORCE_COLOR` not set to a valid value ("0" or empty value is treated as "unset". `FORCE_COLOR` has
120 |     /// higher priority than `NO_COLOR` if set).
121 |     public static var enabled = environmentAvailable
    |                       |- warning: static property 'enabled' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                       |- note: convert 'enabled' to a 'let' constant to make 'Sendable' shared state immutable
    |                       |- note: add '@MainActor' to make static property 'enabled' part of global actor 'MainActor'
    |                       `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
122 |
123 |     public static func extractEntry(for string: String) -> Entry {
[13/23] Compiling Rainbow StyledStringBuilder.swift
[14/23] Compiling Rainbow ConditionalStyleBuilder.swift
[15/23] Compiling Rainbow ControlCode.swift
[16/23] Compiling Rainbow HSLColorConverter.swift
[17/23] Compiling Rainbow ModesExtractor.swift
[18/23] Compiling Rainbow OutputTarget.swift
/host/spi-builder-workspace/Sources/OutputTarget.swift:46:16: warning: static property 'current' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
44 |
45 |     /// Detected output target by current environment.
46 |     static var current: OutputTarget = {
   |                |- warning: static property 'current' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
   |                |- note: convert 'current' to a 'let' constant to make 'Sendable' shared state immutable
   |                |- note: add '@MainActor' to make static property 'current' part of global actor 'MainActor'
   |                `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
47 |         // Check if we are in any term env and the output is a tty.
48 |         let termType = getEnvValue("TERM")
/host/spi-builder-workspace/Sources/OutputTarget.swift:49:72: warning: reference to var 'stdout' is not concurrency-safe because it involves shared mutable state; this is an error in the Swift 6 language mode
47 |         // Check if we are in any term env and the output is a tty.
48 |         let termType = getEnvValue("TERM")
49 |         if let t = termType, t.lowercased() != "dumb" && isatty(fileno(stdout)) != 0 {
   |                                                                        `- warning: reference to var 'stdout' is not concurrency-safe because it involves shared mutable state; this is an error in the Swift 6 language mode
50 |             return .console
51 |         }
/usr/include/stdio.h:144:14: note: var declared here
142 | /* Standard streams.  */
143 | extern FILE *stdin;		/* Standard input stream.  */
144 | extern FILE *stdout;		/* Standard output stream.  */
    |              `- note: var declared here
145 | extern FILE *stderr;		/* Standard error output stream.  */
146 | /* C89/C99 say they're macros.  Make them happy.  */
/host/spi-builder-workspace/Sources/Rainbow.swift:98:23: warning: static property 'outputTarget' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 96 |     /// Output target for `Rainbow`. `Rainbow` should detect correct target itself, so you rarely need to set it.
 97 |     /// However, if you want the colorized string to be different, or the detection is not correct, you can set it manually.
 98 |     public static var outputTarget = OutputTarget.current
    |                       |- warning: static property 'outputTarget' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                       |- note: convert 'outputTarget' to a 'let' constant to make 'Sendable' shared state immutable
    |                       |- note: add '@MainActor' to make static property 'outputTarget' part of global actor 'MainActor'
    |                       `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 99 |
100 |     static var environment = ProcessInfo.processInfo.environment
/host/spi-builder-workspace/Sources/Rainbow.swift:100:16: warning: static property 'environment' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 98 |     public static var outputTarget = OutputTarget.current
 99 |
100 |     static var environment = ProcessInfo.processInfo.environment
    |                |- warning: static property 'environment' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                |- note: convert 'environment' to a 'let' constant to make 'Sendable' shared state immutable
    |                |- note: add '@MainActor' to make static property 'environment' part of global actor 'MainActor'
    |                `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
101 |     static func hasValidValueInEnvironment(_ key: String) -> Bool {
102 |         guard !key.isEmpty, let value = environment[key] else {
/host/spi-builder-workspace/Sources/Rainbow.swift:121:23: warning: static property 'enabled' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
119 |     /// set and `FORCE_COLOR` not set to a valid value ("0" or empty value is treated as "unset". `FORCE_COLOR` has
120 |     /// higher priority than `NO_COLOR` if set).
121 |     public static var enabled = environmentAvailable
    |                       |- warning: static property 'enabled' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                       |- note: convert 'enabled' to a 'let' constant to make 'Sendable' shared state immutable
    |                       |- note: add '@MainActor' to make static property 'enabled' part of global actor 'MainActor'
    |                       `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
122 |
123 |     public static func extractEntry(for string: String) -> Entry {
[19/23] Compiling Rainbow Rainbow.swift
/host/spi-builder-workspace/Sources/OutputTarget.swift:46:16: warning: static property 'current' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
44 |
45 |     /// Detected output target by current environment.
46 |     static var current: OutputTarget = {
   |                |- warning: static property 'current' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
   |                |- note: convert 'current' to a 'let' constant to make 'Sendable' shared state immutable
   |                |- note: add '@MainActor' to make static property 'current' part of global actor 'MainActor'
   |                `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
47 |         // Check if we are in any term env and the output is a tty.
48 |         let termType = getEnvValue("TERM")
/host/spi-builder-workspace/Sources/OutputTarget.swift:49:72: warning: reference to var 'stdout' is not concurrency-safe because it involves shared mutable state; this is an error in the Swift 6 language mode
47 |         // Check if we are in any term env and the output is a tty.
48 |         let termType = getEnvValue("TERM")
49 |         if let t = termType, t.lowercased() != "dumb" && isatty(fileno(stdout)) != 0 {
   |                                                                        `- warning: reference to var 'stdout' is not concurrency-safe because it involves shared mutable state; this is an error in the Swift 6 language mode
50 |             return .console
51 |         }
/usr/include/stdio.h:144:14: note: var declared here
142 | /* Standard streams.  */
143 | extern FILE *stdin;		/* Standard input stream.  */
144 | extern FILE *stdout;		/* Standard output stream.  */
    |              `- note: var declared here
145 | extern FILE *stderr;		/* Standard error output stream.  */
146 | /* C89/C99 say they're macros.  Make them happy.  */
/host/spi-builder-workspace/Sources/Rainbow.swift:98:23: warning: static property 'outputTarget' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 96 |     /// Output target for `Rainbow`. `Rainbow` should detect correct target itself, so you rarely need to set it.
 97 |     /// However, if you want the colorized string to be different, or the detection is not correct, you can set it manually.
 98 |     public static var outputTarget = OutputTarget.current
    |                       |- warning: static property 'outputTarget' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                       |- note: convert 'outputTarget' to a 'let' constant to make 'Sendable' shared state immutable
    |                       |- note: add '@MainActor' to make static property 'outputTarget' part of global actor 'MainActor'
    |                       `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
 99 |
100 |     static var environment = ProcessInfo.processInfo.environment
/host/spi-builder-workspace/Sources/Rainbow.swift:100:16: warning: static property 'environment' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
 98 |     public static var outputTarget = OutputTarget.current
 99 |
100 |     static var environment = ProcessInfo.processInfo.environment
    |                |- warning: static property 'environment' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                |- note: convert 'environment' to a 'let' constant to make 'Sendable' shared state immutable
    |                |- note: add '@MainActor' to make static property 'environment' part of global actor 'MainActor'
    |                `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
101 |     static func hasValidValueInEnvironment(_ key: String) -> Bool {
102 |         guard !key.isEmpty, let value = environment[key] else {
/host/spi-builder-workspace/Sources/Rainbow.swift:121:23: warning: static property 'enabled' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
119 |     /// set and `FORCE_COLOR` not set to a valid value ("0" or empty value is treated as "unset". `FORCE_COLOR` has
120 |     /// higher priority than `NO_COLOR` if set).
121 |     public static var enabled = environmentAvailable
    |                       |- warning: static property 'enabled' is not concurrency-safe because it is nonisolated global shared mutable state; this is an error in the Swift 6 language mode
    |                       |- note: convert 'enabled' to a 'let' constant to make 'Sendable' shared state immutable
    |                       |- note: add '@MainActor' to make static property 'enabled' part of global actor 'MainActor'
    |                       `- note: disable concurrency-safety checks if accesses are protected by an external synchronization mechanism
122 |
123 |     public static func extractEntry(for string: String) -> Entry {
[20/24] Wrapping AST for Rainbow for debugging
[22/26] Compiling RainbowPlayground main.swift
[23/26] Emitting module RainbowPlayground
[24/27] Wrapping AST for RainbowPlayground for debugging
[25/27] Write Objects.LinkFileList
[26/27] Linking RainbowPlayground
Build complete! (8.90s)
Build complete.
{
  "dependencies" : [
  ],
  "manifest_display_name" : "Rainbow",
  "name" : "Rainbow",
  "path" : "/host/spi-builder-workspace",
  "platforms" : [
  ],
  "products" : [
    {
      "name" : "Rainbow",
      "targets" : [
        "Rainbow"
      ],
      "type" : {
        "library" : [
          "automatic"
        ]
      }
    },
    {
      "name" : "RainbowPlayground",
      "targets" : [
        "RainbowPlayground"
      ],
      "type" : {
        "executable" : null
      }
    }
  ],
  "targets" : [
    {
      "c99name" : "RainbowTests",
      "module_type" : "SwiftTarget",
      "name" : "RainbowTests",
      "path" : "Tests",
      "sources" : [
        "RainbowTests/ColorApproximatedTests.swift",
        "RainbowTests/ColorTests.swift",
        "RainbowTests/ConditionalStylingTests.swift",
        "RainbowTests/ConsoleStringTests.swift",
        "RainbowTests/ConsoleTextParserTests.swift",
        "RainbowTests/EdgeCaseTests.swift",
        "RainbowTests/HSLColorTests.swift",
        "RainbowTests/PerformanceTests.swift",
        "RainbowTests/RainbowTests.swift",
        "RainbowTests/StyledStringBuilderTests.swift"
      ],
      "target_dependencies" : [
        "Rainbow"
      ],
      "type" : "test"
    },
    {
      "c99name" : "RainbowPlayground",
      "module_type" : "SwiftTarget",
      "name" : "RainbowPlayground",
      "path" : "Playground",
      "product_memberships" : [
        "RainbowPlayground"
      ],
      "sources" : [
        "main.swift"
      ],
      "target_dependencies" : [
        "Rainbow"
      ],
      "type" : "executable"
    },
    {
      "c99name" : "Rainbow",
      "module_type" : "SwiftTarget",
      "name" : "Rainbow",
      "path" : "Sources",
      "product_memberships" : [
        "Rainbow",
        "RainbowPlayground"
      ],
      "sources" : [
        "BackgroundColor.swift",
        "CodesParser.swift",
        "Color.swift",
        "ColorApproximation.swift",
        "ConditionalStyleBuilder.swift",
        "ControlCode.swift",
        "HSLColorConverter.swift",
        "ModesExtractor.swift",
        "OutputTarget.swift",
        "Rainbow.swift",
        "String+ConditionalStyling.swift",
        "String+Rainbow.swift",
        "StringGenerator.swift",
        "Style.swift",
        "StyledStringBuilder.swift"
      ],
      "type" : "library"
    }
  ],
  "tools_version" : "4.0"
}
basic-6.1-latest: Pulling from finestructure/spi-images
Digest: sha256:2e2b3aca8600f890617c2faa770b70e33c1dfd303d6f92b308423b89ef6bde64
Status: Image is up to date for registry.gitlab.com/finestructure/spi-images:basic-6.1-latest
Done.