Build Information
Successful build of BCrypt with Swift 6.0 for Linux.
Swift 6 data race errors: 2
Build Command
bash -c docker run --rm -v "checkouts-4609320-1":/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/vapor-community/bcrypt.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/vapor-community/bcrypt
* branch master -> FETCH_HEAD
* [new branch] master -> origin/master
HEAD is now at 7b8bf62 Update README.md
Cloned https://github.com/vapor-community/bcrypt.git
Revision (git rev-parse @):
7b8bf62f997d4098804f2a06f205370b6f3c7c8b
SUCCESS checkout https://github.com/vapor-community/bcrypt.git at master
========================================
Build
========================================
Selected platform: linux
Swift version: 6.0
Building package at path: $workDir
https://github.com/vapor-community/bcrypt.git
Running build ...
bash -c docker run --rm -v "checkouts-4609320-1":/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
Fetching https://github.com/vapor/random.git
Fetching https://github.com/vapor/core.git
Fetching https://github.com/vapor/debugging.git
Fetching https://github.com/vapor/bits.git
[1/358] Fetching bits
[359/20501] Fetching bits, core
[360/20649] Fetching bits, core, random
[910/20909] Fetching bits, core, random, debugging
Fetched https://github.com/vapor/bits.git from cache (0.27s)
[5243/20551] Fetching core, random, debugging
Fetched https://github.com/vapor/random.git from cache (0.80s)
Fetched https://github.com/vapor/debugging.git from cache (0.80s)
Computing version for https://github.com/vapor/random.git
Fetched https://github.com/vapor/core.git from cache (0.82s)
Computed https://github.com/vapor/random.git at 1.2.0 (0.50s)
Computing version for https://github.com/vapor/core.git
Computed https://github.com/vapor/core.git at 2.1.1 (0.53s)
Computing version for https://github.com/vapor/debugging.git
Computed https://github.com/vapor/debugging.git at 1.1.0 (0.52s)
Computing version for https://github.com/vapor/bits.git
Computed https://github.com/vapor/bits.git at 1.1.0 (0.51s)
Creating working copy for https://github.com/vapor/bits.git
Working copy of https://github.com/vapor/bits.git resolved at 1.1.0
Creating working copy for https://github.com/vapor/random.git
Working copy of https://github.com/vapor/random.git resolved at 1.2.0
Creating working copy for https://github.com/vapor/debugging.git
Working copy of https://github.com/vapor/debugging.git resolved at 1.1.0
Creating working copy for https://github.com/vapor/core.git
Working copy of https://github.com/vapor/core.git resolved at 2.1.1
Building for debugging...
[0/7] Write sources
[6/7] Write swift-version-24593BA9C3E375BF.txt
[8/29] Emitting module Bits
[9/31] Emitting module Debugging
[10/31] Compiling Debugging Debuggable.swift
[11/32] Compiling Bits Operators.swift
[12/32] Compiling Bits String+BytesConvertible.swift
[14/32] Compiling Bits UnsignedInteger+BytesConvertible.swift
[15/32] Compiling Bits UnsignedInteger+Shifting.swift
[16/32] Emitting module libc
[17/32] Compiling libc libc.swift
[19/33] Compiling Bits Aliases.swift
[20/33] Compiling Bits Base64Encoder.swift
[21/33] Compiling Bits Byte+Alphabet.swift
[22/33] Compiling Bits Byte+Random.swift
[23/33] Compiling Bits Byte+UTF8Numbers.swift
[24/33] Compiling Bits ByteSequence+Conversions.swift
[25/33] Compiling Bits Data+BytesConvertible.swift
[26/33] Compiling Bits HexEncoder.swift
[27/33] Compiling Bits Bytes+Percent.swift
[28/33] Compiling Bits BytesConvertible.swift
[29/33] Compiling Bits Byte+ControlCharacters.swift
[30/33] Compiling Bits Byte+Convenience.swift
[31/33] Compiling Bits Byte+PatternMatching.swift
[32/33] Compiling Bits Bytes+Base64.swift
[33/33] Compiling Bits Bytes+Hex.swift
[35/56] Compiling Core DispatchTime+Utilities.swift
[36/56] Compiling Core EmptyInitializable.swift
[37/56] Compiling Core Exports.swift
[38/56] Compiling Core Result.swift
[39/56] Compiling Core Semaphore.swift
[40/56] Compiling Core Sequence.swift
[41/58] Compiling Core Extendable.swift
[42/58] Compiling Core FileProtocol.swift
[43/58] Compiling Core Int+Hex.swift
[44/58] Emitting module Core
[45/58] Compiling Core Lock.swift
[46/58] Compiling Core Portal.swift
[47/58] Compiling Core RFC1123.swift
[48/58] Compiling Core String.swift
[49/58] Compiling Core WorkingDirectory.swift
[50/58] Compiling Core Collection+Safe.swift
[51/58] Compiling Core DataFile.swift
[52/58] Compiling Core Dispatch.swift
[53/58] Compiling Core StaticDataBuffer.swift
[54/58] Compiling Core String+CaseInsensitiveCompare.swift
[55/58] Compiling Core String+Polymorphic.swift
[56/58] Compiling Core Array.swift
[57/58] Compiling Core Bits.swift
[58/58] Compiling Core Cache.swift
[60/66] Compiling Random EmptyInitializable.swift
[61/66] Compiling Random Array+Random.swift
[62/66] Emitting module Random
[63/66] Compiling Random URandom.swift
[64/66] Compiling Random RandomProtocol.swift
[65/66] Compiling Random Exports.swift
[66/66] Compiling Random OSRandom.swift
[68/76] Compiling BCrypt Convenience.swift
[69/77] Compiling BCrypt Parser.swift
[70/77] Compiling BCrypt Salt.swift
/host/spi-builder-workspace/Sources/BCrypt/Salt.swift:4:23: warning: static property 'defaultRandom' is not concurrency-safe because it is non-isolated global shared mutable state; this is an error in the Swift 6 language mode
2 |
3 | public struct Salt {
4 | public static var defaultRandom: RandomProtocol = OSRandom()
| |- warning: static property 'defaultRandom' is not concurrency-safe because it is non-isolated global shared mutable state; this is an error in the Swift 6 language mode
| |- note: convert 'defaultRandom' to a 'let' constant to make 'Sendable' shared state immutable
| |- note: annotate 'defaultRandom' 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
5 | public static var defaultCost: UInt = 6
6 |
/host/spi-builder-workspace/Sources/BCrypt/Salt.swift:5:23: warning: static property 'defaultCost' is not concurrency-safe because it is non-isolated global shared mutable state; this is an error in the Swift 6 language mode
3 | public struct Salt {
4 | public static var defaultRandom: RandomProtocol = OSRandom()
5 | public static var defaultCost: UInt = 6
| |- warning: static property 'defaultCost' is not concurrency-safe because it is non-isolated global shared mutable state; this is an error in the Swift 6 language mode
| |- note: convert 'defaultCost' to a 'let' constant to make 'Sendable' shared state immutable
| |- note: annotate 'defaultCost' 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
6 |
7 | public enum Version {
[71/77] Compiling BCrypt Keys.swift
[72/77] Compiling BCrypt Serializer.swift
[73/77] Emitting module BCrypt
/host/spi-builder-workspace/Sources/BCrypt/Salt.swift:4:23: warning: static property 'defaultRandom' is not concurrency-safe because it is non-isolated global shared mutable state; this is an error in the Swift 6 language mode
2 |
3 | public struct Salt {
4 | public static var defaultRandom: RandomProtocol = OSRandom()
| |- warning: static property 'defaultRandom' is not concurrency-safe because it is non-isolated global shared mutable state; this is an error in the Swift 6 language mode
| |- note: convert 'defaultRandom' to a 'let' constant to make 'Sendable' shared state immutable
| |- note: annotate 'defaultRandom' 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
5 | public static var defaultCost: UInt = 6
6 |
/host/spi-builder-workspace/Sources/BCrypt/Salt.swift:5:23: warning: static property 'defaultCost' is not concurrency-safe because it is non-isolated global shared mutable state; this is an error in the Swift 6 language mode
3 | public struct Salt {
4 | public static var defaultRandom: RandomProtocol = OSRandom()
5 | public static var defaultCost: UInt = 6
| |- warning: static property 'defaultCost' is not concurrency-safe because it is non-isolated global shared mutable state; this is an error in the Swift 6 language mode
| |- note: convert 'defaultCost' to a 'let' constant to make 'Sendable' shared state immutable
| |- note: annotate 'defaultCost' 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
6 |
7 | public enum Version {
[74/77] Compiling BCrypt BCryptError.swift
[75/77] Compiling BCrypt Base64.swift
[76/77] Compiling BCrypt Export.swift
[77/77] Compiling BCrypt Hash.swift
/host/spi-builder-workspace/Sources/BCrypt/Hash.swift:18:19: warning: initialization of 'UnsafeMutableRawPointer' results in a dangling pointer
16 | .allocate(capacity: Key.p.count)
17 | p.initialize(
18 | from: UnsafeMutableRawPointer(mutating: Key.p)
| | |- note: implicit argument conversion from '[UInt32]' to 'UnsafeRawPointer' produces a pointer valid only for the duration of the call to 'init(mutating:)'
| | `- note: use the 'withUnsafeBytes' method on Array in order to explicitly convert argument to buffer pointer valid for a defined scope
| `- warning: initialization of 'UnsafeMutableRawPointer' results in a dangling pointer
19 | .assumingMemoryBound(to: UInt32.self),
20 | count: Key.p.count
/host/spi-builder-workspace/Sources/BCrypt/Hash.swift:26:19: warning: initialization of 'UnsafeMutableRawPointer' results in a dangling pointer
24 | .allocate(capacity: Key.s.count)
25 | s.initialize(
26 | from: UnsafeMutableRawPointer(mutating: Key.s)
| | |- note: implicit argument conversion from '[UInt32]' to 'UnsafeRawPointer' produces a pointer valid only for the duration of the call to 'init(mutating:)'
| | `- note: use the 'withUnsafeBytes' method on Array in order to explicitly convert argument to buffer pointer valid for a defined scope
| `- warning: initialization of 'UnsafeMutableRawPointer' results in a dangling pointer
27 | .assumingMemoryBound(to: UInt32.self),
28 | count: Key.s.count
/host/spi-builder-workspace/Sources/BCrypt/Salt.swift:5:23: warning: static property 'defaultCost' is not concurrency-safe because it is non-isolated global shared mutable state; this is an error in the Swift 6 language mode
3 | public struct Salt {
4 | public static var defaultRandom: RandomProtocol = OSRandom()
5 | public static var defaultCost: UInt = 6
| |- warning: static property 'defaultCost' is not concurrency-safe because it is non-isolated global shared mutable state; this is an error in the Swift 6 language mode
| |- note: convert 'defaultCost' to a 'let' constant to make 'Sendable' shared state immutable
| |- note: annotate 'defaultCost' 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
6 |
7 | public enum Version {
/host/spi-builder-workspace/Sources/BCrypt/Hash.swift:180:56: warning: initialization of 'UnsafeMutablePointer<UInt8>' results in a dangling pointer
178 | let slen: Int = 1024
179 |
180 | let keyPointer : UnsafeMutablePointer<UInt8> = UnsafeMutablePointer<UInt8>(mutating: key)
| | |- note: implicit argument conversion from 'Bytes' (aka 'Array<UInt8>') to 'UnsafePointer<UInt8>' produces a pointer valid only for the duration of the call to 'init(mutating:)'
| | `- note: use the 'withUnsafeBufferPointer' method on Array in order to explicitly convert argument to buffer pointer valid for a defined scope
| `- warning: initialization of 'UnsafeMutablePointer<UInt8>' results in a dangling pointer
181 | let keyLength : Int = key.count
182 |
/host/spi-builder-workspace/Sources/BCrypt/Hash.swift:212:55: warning: initialization of 'UnsafeMutablePointer<UInt8>' results in a dangling pointer
210 | var lr: [UInt32] = [0, 0]
211 |
212 | let keyPointer: UnsafeMutablePointer<UInt8> = UnsafeMutablePointer<UInt8>(mutating: key)
| | |- note: implicit argument conversion from '[UInt8]' to 'UnsafePointer<UInt8>' produces a pointer valid only for the duration of the call to 'init(mutating:)'
| | `- note: use the 'withUnsafeBufferPointer' method on Array in order to explicitly convert argument to buffer pointer valid for a defined scope
| `- warning: initialization of 'UnsafeMutablePointer<UInt8>' results in a dangling pointer
213 | let keyLength: Int = key.count
214 | let dataPointer: UnsafeMutablePointer<UInt8> = UnsafeMutablePointer<UInt8>(mutating: data)
/host/spi-builder-workspace/Sources/BCrypt/Hash.swift:214:56: warning: initialization of 'UnsafeMutablePointer<UInt8>' results in a dangling pointer
212 | let keyPointer: UnsafeMutablePointer<UInt8> = UnsafeMutablePointer<UInt8>(mutating: key)
213 | let keyLength: Int = key.count
214 | let dataPointer: UnsafeMutablePointer<UInt8> = UnsafeMutablePointer<UInt8>(mutating: data)
| | |- note: implicit argument conversion from '[UInt8]' to 'UnsafePointer<UInt8>' produces a pointer valid only for the duration of the call to 'init(mutating:)'
| | `- note: use the 'withUnsafeBufferPointer' method on Array in order to explicitly convert argument to buffer pointer valid for a defined scope
| `- warning: initialization of 'UnsafeMutablePointer<UInt8>' results in a dangling pointer
215 | let dataLength: Int = data.count
216 |
Build complete! (28.56s)
Build complete.
{
"dependencies" : [
{
"identity" : "random",
"requirement" : {
"range" : [
{
"lower_bound" : "1.2.0",
"upper_bound" : "2.0.0"
}
]
},
"type" : "sourceControl",
"url" : "https://github.com/vapor/random.git"
}
],
"manifest_display_name" : "BCrypt",
"name" : "BCrypt",
"path" : "/host/spi-builder-workspace",
"platforms" : [
],
"products" : [
{
"name" : "BCrypt",
"targets" : [
"BCrypt"
],
"type" : {
"library" : [
"automatic"
]
}
}
],
"targets" : [
{
"c99name" : "BCryptTests",
"module_type" : "SwiftTarget",
"name" : "BCryptTests",
"path" : "Tests/BCryptTests",
"sources" : [
"BCryptTests.swift"
],
"target_dependencies" : [
"BCrypt"
],
"type" : "test"
},
{
"c99name" : "BCrypt",
"module_type" : "SwiftTarget",
"name" : "BCrypt",
"path" : "Sources/BCrypt",
"product_dependencies" : [
"Random"
],
"product_memberships" : [
"BCrypt"
],
"sources" : [
"BCryptError.swift",
"Base64.swift",
"Convenience.swift",
"Export.swift",
"Hash.swift",
"Keys.swift",
"Parser.swift",
"Salt.swift",
"Serializer.swift"
],
"type" : "library"
}
],
"tools_version" : "4.0"
}
Done.