Build Information
Successful build of StorageKit, reference main (0c6744), with Swift 6.3 for macOS (SPM) on 16 Apr 2026 21:11:59 UTC.
Swift 6 data race errors: 0
Build Command
env DEVELOPER_DIR=/Applications/Xcode-26.4.0.app xcrun swift build --arch arm64Build Log
========================================
RunAll
========================================
Builder version: 4.70.0
Interrupt handler set up.
========================================
Checkout
========================================
Clone URL: https://github.com/NikSativa/StorageKit.git
Reference: main
Initialized empty Git repository in /Users/admin/builder/spi-builder-workspace/.git/
From https://github.com/NikSativa/StorageKit
* branch main -> FETCH_HEAD
* [new branch] main -> origin/main
HEAD is now at 0c6744f align platform versions and dependency requirements
Cloned https://github.com/NikSativa/StorageKit.git
Revision (git rev-parse @):
0c6744f6f113dcf61d6d17a5594d1a7d8f334b60
SPI manifest file found: $PWD/.spi.yml
SUCCESS checkout https://github.com/NikSativa/StorageKit.git at main
========================================
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",
"traits": [
"default"
],
"dependencies": [
{
"identity": "storagekit",
"name": "StorageKit",
"url": "https://github.com/NikSativa/StorageKit.git",
"version": "unspecified",
"path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/StorageKit",
"traits": [
"default"
],
"dependencies": [
]
}
]
}
Fetching https://github.com/NikSativa/StorageKit.git
[1/182] Fetching storagekit
Fetched https://github.com/NikSativa/StorageKit.git from cache (0.68s)
Creating working copy for https://github.com/NikSativa/StorageKit.git
Working copy of https://github.com/NikSativa/StorageKit.git resolved at main (0c6744f)
warning: '.resolve-product-dependencies': dependency 'storagekit' is not used by any target
Found 0 product dependencies
========================================
Build
========================================
Selected platform: macosSpm
Swift version: 6.3
Building package at path: $PWD
https://github.com/NikSativa/StorageKit.git
Running build ...
env DEVELOPER_DIR=/Applications/Xcode-26.4.0.app xcrun swift build --arch arm64
Building for debugging...
[0/3] Copying PrivacyInfo.xcprivacy
[0/3] Write sources
[2/3] Write swift-version--6988338F2F200930.txt
[4/16] Compiling StorageKit Stored.swift
[5/17] Compiling StorageKit UserDefaultsStorage.swift
[6/17] Compiling StorageKit KeychainStorage.swift
[7/17] Compiling StorageKit InMemoryStorage.swift
[8/17] Compiling StorageKit AnyStorage.swift
[9/17] Compiling StorageKit Storage.swift
[10/17] Compiling StorageKit StorageComposition.swift
[11/17] Emitting module StorageKit
[12/17] Compiling StorageKit Keychain.swift
[13/17] Compiling StorageKit Lifetime.swift
[14/17] Compiling StorageKit Defaults.swift
[15/17] Compiling StorageKit Expirable.swift
[16/17] Compiling StorageKit FileStorage.swift
[17/17] Compiling StorageKit resource_bundle_accessor.swift
Build complete! (5.30s)
Build complete.
{
"dependencies" : [
],
"manifest_display_name" : "StorageKit",
"name" : "StorageKit",
"path" : "/Users/admin/builder/spi-builder-workspace",
"platforms" : [
{
"name" : "ios",
"version" : "16.0"
},
{
"name" : "macos",
"version" : "14.0"
},
{
"name" : "maccatalyst",
"version" : "16.0"
},
{
"name" : "visionos",
"version" : "1.0"
},
{
"name" : "tvos",
"version" : "16.0"
},
{
"name" : "watchos",
"version" : "9.0"
}
],
"products" : [
{
"name" : "StorageKit",
"targets" : [
"StorageKit"
],
"type" : {
"library" : [
"automatic"
]
}
}
],
"targets" : [
{
"c99name" : "StorageKitTests",
"module_type" : "SwiftTarget",
"name" : "StorageKitTests",
"path" : "Tests",
"sources" : [
"DefaultsTests.swift",
"StorageTests.swift"
],
"target_dependencies" : [
"StorageKit"
],
"type" : "test"
},
{
"c99name" : "StorageKit",
"module_type" : "SwiftTarget",
"name" : "StorageKit",
"path" : "Source",
"product_memberships" : [
"StorageKit"
],
"resources" : [
{
"path" : "/Users/admin/builder/spi-builder-workspace/Source/PrivacyInfo.xcprivacy",
"rule" : {
"process" : {
}
}
}
],
"sources" : [
"Defaults.swift",
"Expirable.swift",
"Keychain.swift",
"Lifetime.swift",
"Storage.swift",
"StorageComposition.swift",
"Storages/AnyStorage.swift",
"Storages/FileStorage.swift",
"Storages/InMemoryStorage.swift",
"Storages/KeychainStorage.swift",
"Storages/UserDefaultsStorage.swift",
"Stored.swift"
],
"type" : "library"
}
],
"tools_version" : "6.0"
}
✅ Doc result (pending) reported
========================================
GenerateDocs
========================================
Generating docs at path: $PWD/.docs/niksativa/storagekit/main
Repository: NikSativa/StorageKit
Swift version used: 6.3
Target: StorageKit
Extracting symbol information for 'StorageKit'...
Finished extracting symbol information for 'StorageKit'. (28.55s)
Building documentation for 'StorageKit'...
warning: External name 'wrappedValue' used to document parameter
--> Source/Defaults.swift:76:13-76:25
74 | ///
75 | /// - Parameters:
76 + /// - wrappedValue: The default value used when no value is stored.
| ╰─suggestion: Replace 'wrappedValue' with 'defaultValue'
77 | /// - key: The `UserDefaults` key used for storage.
78 | /// - decoder: An optional closure that provides a custom `JSONDecoder`.
warning: Parameter 'defaultValue' is missing documentation
--> Source/Expirable.swift:44:85-44:85
42 | /// - Parameters:
43 | /// - wrappedValue: The initial value to store.
44 + /// - interval: The number of seconds the value remains valid before expiring.
| ╰─suggestion: Document 'defaultValue' parameter
45 | public init(wrappedValue: Value,
46 | defaultValue: Value,
warning: Parameter 'defaultValue' is missing documentation
--> Source/Expirable.swift:57:89-57:89
55 | /// - Parameters:
56 | /// - wrappedValue: The initial value to store.
57 + /// - lifetime: A `Lifetime` object that defines how long the value remains valid.
| ╰─suggestion: Document 'defaultValue' parameter
58 | public init(wrappedValue: Value,
59 | defaultValue: Value,
warning: Parameter 'defaultValue' is missing documentation
--> Source/Storage.swift:194:59-194:59
192 | /// Available on iOS 16.0+, macOS 13+, tvOS 16.0+, and watchOS 9.0+.
193 | ///
194 + /// - Parameter storages: An array of storages to combine.
| ╰─suggestion: Document 'defaultValue' parameter
195 | /// - Returns: A new `Storage` that reflects the combined state.
196 | @available(macOS 13, iOS 16, tvOS 16.0, watchOS 9.0, *)
warning: Parameter 'defaultValue' is missing documentation
--> Source/Storages/FileStorage.swift:44:9-44:9
42 | /// - fileName: The name of the file used for storage. The file will be saved with a `.stg` extension.
43 | /// - fileManager: The file manager to use for reading and writing. Defaults to `.default`.
| ╰─suggestion: Document 'defaultValue' parameter
44 + ///
45 | /// The file is created in the app's Caches directory inside a "Storages" folder.
46 | public convenience init(fileName: String,
warning: Parameter 'defaultValue' is missing documentation
--> Source/Storages/FileStorage.swift:76:65-76:65
74 | /// - fileName: The name used to identify the storage file.
75 | /// - fileManager: The file manager responsible for file operations.
76 + /// - filePath: The full URL of the file used for storage.
| ╰─suggestion: Document 'defaultValue' parameter
77 | public required init(fileName: String,
78 | fileManager: FileManager = .default,
warning: Parameter 'decoder' is missing documentation
--> Source/Storages/KeychainStorage.swift:21:48-21:48
19 | /// - parameter service: unique id for app. in common case is bundle id.
20 | /// - parameter accessGroup: unique id for filter app scope. in common case is nil, but if service is not unique between apps, then group can help to filter values only for corresponding group.
21 + /// - parameter synchronizable: iCloud sync
| ╰─suggestion: Document 'decoder' parameter
22 | public init(service: String,
23 | accessGroup: String? = nil,
warning: Parameter 'encoder' is missing documentation
--> Source/Storages/KeychainStorage.swift:21:48-21:48
19 | /// - parameter service: unique id for app. in common case is bundle id.
20 | /// - parameter accessGroup: unique id for filter app scope. in common case is nil, but if service is not unique between apps, then group can help to filter values only for corresponding group.
21 + /// - parameter synchronizable: iCloud sync
| ╰─suggestion: Document 'encoder' parameter
22 | public init(service: String,
23 | accessGroup: String? = nil,
warning: Parameter 'defaultValue' is missing documentation
--> Source/Storages/KeychainStorage.swift:90:93-90:93
88 | /// - Parameters:
89 | /// - key: The key used to store and retrieve the value in the Keychain.
90 + /// - keychain: A `Keychain` instance that provides access to the secure storage APIs.
| ╰─suggestion: Document 'defaultValue' parameter
91 | public init(key: String, defaultValue: Value, keychain: Keychain) {
92 | self.key = key
warning: Parameter 'defaultValue' is missing documentation
--> Source/Storages/KeychainStorage.swift:101:96-101:96
99 | /// - Parameters:
100 | /// - key: The key used to store and retrieve the value in the Keychain.
101 + /// - configuration: A `KeychainConfiguration` that defines how the Keychain is accessed.
| ╰─suggestion: Document 'defaultValue' parameter
102 | public convenience init(key: String, defaultValue: Value, configuration: KeychainConfiguration) {
103 | self.init(key: key, defaultValue: defaultValue, keychain: .init(configuration: configuration))
warning: Parameter 'defaultValue' is missing documentation
--> Source/Storages/UserDefaultsStorage.swift:42:83-42:83
40 | /// - Parameters:
41 | /// - key: The key used to store and retrieve the value.
42 + /// - defaults: The `UserDefaults` instance to use. Defaults to `.standard`.
| ╰─suggestion: Document 'defaultValue' parameter
43 | public init(key: String, defaultValue: Value, defaults: UserDefaults = .standard) {
44 | self.key = key
warning: Parameter 'defaultValue' is missing documentation
--> Source/Stored.swift:40:77-40:77
38 | /// Creates a wrapper that synchronizes multiple storages.
39 | ///
40 + /// - Parameter base: Storages to combine into one synchronized storage.
| ╰─suggestion: Document 'defaultValue' parameter
41 | @available(macOS 13.0, iOS 16.0, tvOS 16.0, watchOS 9.0, *)
42 | public init(storages base: [any Storage<Value>], defaultValue: Value) throws {
Finished building documentation for 'StorageKit' (0.50s)
Generated documentation archive at:
/Users/admin/builder/spi-builder-workspace/.docs/niksativa/storagekit/main
Fetching https://github.com/swiftlang/swift-docc-plugin
[1/2277] Fetching swift-docc-plugin
Fetched https://github.com/swiftlang/swift-docc-plugin from cache (1.11s)
Computing version for https://github.com/swiftlang/swift-docc-plugin
Computed https://github.com/swiftlang/swift-docc-plugin at 1.4.6 (3.51s)
Fetching https://github.com/swiftlang/swift-docc-symbolkit
[1/3672] Fetching swift-docc-symbolkit
Fetched https://github.com/swiftlang/swift-docc-symbolkit from cache (1.06s)
Computing version for https://github.com/swiftlang/swift-docc-symbolkit
Computed https://github.com/swiftlang/swift-docc-symbolkit at 1.0.0 (1.82s)
Creating working copy for https://github.com/swiftlang/swift-docc-symbolkit
Working copy of https://github.com/swiftlang/swift-docc-symbolkit resolved at 1.0.0
Creating working copy for https://github.com/swiftlang/swift-docc-plugin
Working copy of https://github.com/swiftlang/swift-docc-plugin resolved at 1.4.6
Building for debugging...
[0/8] Write sources
[1/8] Write snippet-extract-tool-entitlement.plist
[3/8] Write sources
[4/8] Write swift-version--6988338F2F200930.txt
[6/53] Compiling Snippets Snippet.swift
[7/53] Compiling Snippets SnippetParser.swift
[8/53] Emitting module Snippets
[9/53] Compiling SymbolKit Mixin+Equals.swift
[10/53] Compiling SymbolKit Mixin+Hash.swift
[11/53] Compiling SymbolKit Mixin.swift
[12/53] Compiling SymbolKit LineList.swift
[13/53] Compiling SymbolKit Position.swift
[14/57] Emitting module SymbolKit
[15/57] Compiling SymbolKit SemanticVersion.swift
[16/57] Compiling SymbolKit AccessControl.swift
[17/57] Compiling SymbolKit Availability.swift
[18/57] Compiling SymbolKit AvailabilityItem.swift
[19/57] Compiling SymbolKit Domain.swift
[20/57] Compiling SymbolKit Identifier.swift
[21/57] Compiling SymbolKit KindIdentifier.swift
[22/57] Compiling SymbolKit Location.swift
[23/57] Compiling SymbolKit Mutability.swift
[24/57] Compiling SymbolKit Names.swift
[25/57] Compiling SymbolKit SPI.swift
[26/57] Compiling SymbolKit Snippet.swift
[27/57] Compiling SymbolKit Extension.swift
[28/57] Compiling SymbolKit DeclarationFragments.swift
[29/57] Compiling SymbolKit Fragment.swift
[30/57] Compiling SymbolKit FragmentKind.swift
[31/57] Compiling SymbolKit FunctionParameter.swift
[32/57] Compiling SymbolKit FunctionSignature.swift
[33/57] Compiling SymbolKit GenericConstraint.swift
[34/57] Compiling SymbolKit GenericParameter.swift
[35/57] Compiling SymbolKit Generics.swift
[36/57] Compiling SymbolKit Namespace.swift
[37/57] Compiling SymbolKit Relationship.swift
[38/57] Compiling SymbolKit RelationshipKind.swift
[39/57] Compiling SymbolKit SourceOrigin.swift
[40/57] Compiling SymbolKit GenericConstraints.swift
[41/57] Compiling SymbolKit Swift.swift
[42/57] Compiling SymbolKit SourceRange.swift
[43/57] Compiling SymbolKit Metadata.swift
[44/57] Compiling SymbolKit Module.swift
[45/57] Compiling SymbolKit OperatingSystem.swift
[46/57] Compiling SymbolKit Platform.swift
[47/57] Compiling SymbolKit Symbol.swift
[48/57] Compiling SymbolKit SymbolKind.swift
[49/57] Compiling SymbolKit SymbolGraph.swift
[50/57] Compiling SymbolKit GraphCollector.swift
[51/57] Compiling SymbolKit UnifiedSymbol+Encodable.swift
[52/57] Compiling SymbolKit UnifiedSymbol.swift
[53/57] Compiling SymbolKit UnifiedSymbolGraph+Encodable.swift
[54/57] Compiling SymbolKit UnifiedSymbolGraph.swift
[55/61] Compiling snippet_extract URL+Status.swift
[56/61] Compiling snippet_extract SymbolGraph+Snippet.swift
[57/61] Compiling snippet_extract SnippetBuildCommand.swift
[58/61] Emitting module snippet_extract
[58/61] Write Objects.LinkFileList
[59/61] Linking snippet-extract-tool
[60/61] Applying snippet-extract-tool
Build of product 'snippet-extract' complete! (4.99s)
Building for debugging...
[0/1] Write swift-version--6988338F2F200930.txt
Build of target: 'StorageKit' complete! (0.32s)
674
6 /Users/admin/builder/spi-builder-workspace/.docs/niksativa/storagekit/main
✅ Doc result (uploading) reported
========================================
SyncDocs
========================================
Doc archive source directory: $PWD/.docs/niksativa/storagekit/main
File count: 674
Doc size: 6.0MB
Preparing doc bundle ...
Uploading prod-niksativa-storagekit-main-b2fbe123.zip to s3://spi-docs-inbox/prod-niksativa-storagekit-main-b2fbe123.zip
Copying... [12%]
Copying... [23%]
Copying... [35%]
Copying... [40%]
Copying... [52%]
Copying... [64%]
Copying... [75%]
Copying... [81%]
Copying... [92%]
Copying... [100%]
Done.