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 Vexil, reference main (938572), with Swift 6.2 for macOS (SPM) on 1 Dec 2025 11:01:56 UTC.

Swift 6 data race errors: 0

Build Command

env DEVELOPER_DIR=/Applications/Xcode-26.0.0.app xcrun swift build --arch arm64

Build Log

========================================
RunAll
========================================
Builder version: 4.68.0
Interrupt handler set up.
========================================
Checkout
========================================
Clone URL: https://github.com/unsignedapps/Vexil.git
Reference: main
Initialized empty Git repository in /Users/admin/builder/spi-builder-workspace/.git/
From https://github.com/unsignedapps/Vexil
 * branch            main       -> FETCH_HEAD
 * [new branch]      main       -> origin/main
HEAD is now at 938572d Merge pull request #142 from unsignedapps/fix/vexil3/sendable
Cloned https://github.com/unsignedapps/Vexil.git
Revision (git rev-parse @):
938572d1ddc865bda15e701d6fab38a486716260
SPI manifest file found: $PWD/.spi.yml
SUCCESS checkout https://github.com/unsignedapps/Vexil.git at main
Fetching https://github.com/apple/swift-async-algorithms.git
Fetching https://github.com/nicklockwood/SwiftFormat.git
Fetching https://github.com/swiftlang/swift-syntax.git
[1/5787] Fetching swift-async-algorithms
[5788/78787] Fetching swift-async-algorithms, swift-syntax
[7248/131909] Fetching swift-async-algorithms, swift-syntax, swiftformat
Fetched https://github.com/nicklockwood/SwiftFormat.git from cache (77.88s)
Fetched https://github.com/swiftlang/swift-syntax.git from cache (77.88s)
Fetched https://github.com/apple/swift-async-algorithms.git from cache (77.88s)
Computing version for https://github.com/swiftlang/swift-syntax.git
Computed https://github.com/swiftlang/swift-syntax.git at 602.0.0 (80.55s)
Computing version for https://github.com/apple/swift-async-algorithms.git
Computed https://github.com/apple/swift-async-algorithms.git at 1.1.0 (0.55s)
Fetching https://github.com/apple/swift-collections.git
[1/18314] Fetching swift-collections
Fetched https://github.com/apple/swift-collections.git from cache (2.56s)
Computing version for https://github.com/apple/swift-collections.git
Computed https://github.com/apple/swift-collections.git at 1.3.0 (3.27s)
Computing version for https://github.com/nicklockwood/SwiftFormat.git
Computed https://github.com/nicklockwood/SwiftFormat.git at 0.58.7 (0.61s)
Creating working copy for https://github.com/nicklockwood/SwiftFormat.git
Working copy of https://github.com/nicklockwood/SwiftFormat.git resolved at 0.58.7
Creating working copy for https://github.com/apple/swift-collections.git
Working copy of https://github.com/apple/swift-collections.git resolved at 1.3.0
Creating working copy for https://github.com/apple/swift-async-algorithms.git
Working copy of https://github.com/apple/swift-async-algorithms.git resolved at 1.1.0
Creating working copy for https://github.com/swiftlang/swift-syntax.git
Working copy of https://github.com/swiftlang/swift-syntax.git resolved at 602.0.0
Downloading package prebuilt https://download.swift.org/prebuilts/swift-syntax/602.0.0/swiftlang-6.2.0.19.9-MacroSupport-macos_aarch64.zip
Downloaded https://download.swift.org/prebuilts/swift-syntax/602.0.0/swiftlang-6.2.0.19.9-MacroSupport-macos_aarch64.zip (0.16s)
========================================
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": "vexil",
      "name": "Vexil",
      "url": "https://github.com/unsignedapps/Vexil.git",
      "version": "unspecified",
      "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/Vexil",
      "dependencies": [
        {
          "identity": "swift-async-algorithms",
          "name": "swift-async-algorithms",
          "url": "https://github.com/apple/swift-async-algorithms.git",
          "version": "1.1.0",
          "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/swift-async-algorithms",
          "dependencies": [
            {
              "identity": "swift-collections",
              "name": "swift-collections",
              "url": "https://github.com/apple/swift-collections.git",
              "version": "1.3.0",
              "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/swift-collections",
              "dependencies": [
              ]
            }
          ]
        },
        {
          "identity": "swift-syntax",
          "name": "swift-syntax",
          "url": "https://github.com/swiftlang/swift-syntax.git",
          "version": "602.0.0",
          "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/swift-syntax",
          "dependencies": [
          ]
        }
      ]
    }
  ]
}
Fetching https://github.com/unsignedapps/Vexil.git
[1/12433] Fetching vexil
Fetched https://github.com/unsignedapps/Vexil.git from cache (1.26s)
Fetching https://github.com/swiftlang/swift-syntax.git from cache
Fetching https://github.com/apple/swift-async-algorithms.git from cache
Fetched https://github.com/swiftlang/swift-syntax.git from cache (0.95s)
Fetched https://github.com/apple/swift-async-algorithms.git from cache (0.95s)
Computing version for https://github.com/swiftlang/swift-syntax.git
Computed https://github.com/swiftlang/swift-syntax.git at 602.0.0 (1.02s)
Computing version for https://github.com/apple/swift-async-algorithms.git
Computed https://github.com/apple/swift-async-algorithms.git at 1.1.0 (0.04s)
Fetching https://github.com/apple/swift-collections.git from cache
Fetched https://github.com/apple/swift-collections.git from cache (0.53s)
Computing version for https://github.com/apple/swift-collections.git
Computed https://github.com/apple/swift-collections.git at 1.3.0 (0.60s)
Creating working copy for https://github.com/swiftlang/swift-syntax.git
Working copy of https://github.com/swiftlang/swift-syntax.git resolved at 602.0.0
Creating working copy for https://github.com/unsignedapps/Vexil.git
Working copy of https://github.com/unsignedapps/Vexil.git resolved at main (938572d)
Creating working copy for https://github.com/apple/swift-collections.git
Working copy of https://github.com/apple/swift-collections.git resolved at 1.3.0
Creating working copy for https://github.com/apple/swift-async-algorithms.git
Working copy of https://github.com/apple/swift-async-algorithms.git resolved at 1.1.0
warning: '.resolve-product-dependencies': dependency 'vexil' is not used by any target
Found 2 product dependencies
  - swift-async-algorithms
  - swift-syntax
========================================
Build
========================================
Selected platform:         macosSpm
Swift version:             6.2
Building package at path:  $PWD
https://github.com/unsignedapps/Vexil.git
Running build ...
env DEVELOPER_DIR=/Applications/Xcode-26.0.0.app xcrun swift build --arch arm64
[1/1] Compiling plugin SwiftFormatPlugin
Building for debugging...
[1/16] Write sources
[13/16] Write swift-version-49B95AFC49DCD68C.txt
[15/60] Compiling InternalCollectionsUtilities Descriptions.swift
[16/60] Compiling InternalCollectionsUtilities LifetimeOverride.swift
[17/60] Compiling InternalCollectionsUtilities UnsafeMutableRawBufferPointer+Extras.swift
[18/62] Compiling InternalCollectionsUtilities _UniqueCollection.swift
[19/62] Compiling InternalCollectionsUtilities Debugging.swift
[20/62] Compiling InternalCollectionsUtilities UnsafeMutableRawBufferPointer+Extras.swift
[21/62] Compiling InternalCollectionsUtilities RandomAccessCollection+Offsets.swift
[22/62] Compiling InternalCollectionsUtilities UnsafeBufferPointer+Extras.swift
[23/62] Compiling InternalCollectionsUtilities UnsafeMutableBufferPointer+Extras.swift
[31/62] Compiling InternalCollectionsUtilities UnsafeRawBufferPointer+Extras.swift
[33/62] Compiling InternalCollectionsUtilities _UnsafeBitSet.swift
[34/62] Compiling InternalCollectionsUtilities _SortedCollection.swift
[35/62] Compiling InternalCollectionsUtilities _UnsafeBitSet+Index.swift
[36/62] Compiling InternalCollectionsUtilities _UnsafeBitSet+_Word.swift
[37/62] Compiling InternalCollectionsUtilities UInt+first and last set bit.swift
[38/62] Compiling InternalCollectionsUtilities UInt+reversed.swift
[39/62] Compiling InternalCollectionsUtilities FixedWidthInteger+roundUpToPowerOfTwo.swift
[40/62] Compiling InternalCollectionsUtilities Integer rank.swift
[43/62] Emitting module InternalCollectionsUtilities
[51/206] Compiling DequeModule _DequeSlot.swift
[52/206] Compiling DequeModule _DequeBufferHeader.swift
[53/207] Compiling DequeModule _DequeBuffer.swift
[54/207] Compiling DequeModule _DequeBufferHeader.swift
[55/207] Compiling DequeModule _DequeBuffer.swift
[56/207] Compiling DequeModule _DequeSlot.swift
[57/208] Compiling OrderedCollections OrderedSet+Codable.swift
[58/208] Compiling OrderedCollections OrderedSet+CustomReflectable.swift
[59/208] Compiling OrderedCollections OrderedSet+Descriptions.swift
[60/208] Compiling OrderedCollections OrderedSet+Diffing.swift
[61/208] Compiling OrderedCollections OrderedSet+Equatable.swift
[62/208] Compiling OrderedCollections OrderedSet+ExpressibleByArrayLiteral.swift
[69/220] Compiling DequeModule _UnsafeWrappedBuffer.swift
[71/220] Compiling OrderedCollections _HashTable+Constants.swift
[72/220] Compiling OrderedCollections _HashTable+CustomStringConvertible.swift
[73/220] Compiling OrderedCollections _HashTable+Bucket.swift
[74/220] Compiling OrderedCollections OrderedSet+Codable.swift
[75/220] Compiling OrderedCollections OrderedDictionary+Initializers.swift
[76/220] Compiling OrderedCollections OrderedDictionary+Invariants.swift
[77/220] Compiling OrderedCollections OrderedSet+Diffing.swift
[78/220] Compiling OrderedCollections OrderedSet+Equatable.swift
[87/220] Compiling OrderedCollections _HashTable+Constants.swift
[88/220] Compiling OrderedCollections _HashTable+CustomStringConvertible.swift
[89/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra symmetricDifference.swift
[90/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra union.swift
[91/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra+Basics.swift
[92/220] Compiling OrderedCollections OrderedSet+RandomAccessCollection.swift
[93/220] Compiling OrderedCollections OrderedSet+ReserveCapacity.swift
[94/220] Compiling OrderedCollections OrderedSet+Sendable.swift
[95/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra formIntersection.swift
[96/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra formSymmetricDifference.swift
[97/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra formUnion.swift
[98/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra intersection.swift
[99/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra isDisjoint.swift
[100/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra isEqualSet.swift
[101/220] Compiling OrderedCollections _Hashtable+Header.swift
[102/220] Compiling OrderedCollections OrderedDictionary+Codable.swift
[103/220] Compiling OrderedCollections OrderedDictionary+CustomReflectable.swift
[104/220] Compiling OrderedCollections OrderedDictionary+Deprecations.swift
[105/220] Compiling OrderedCollections OrderedDictionary+Descriptions.swift
[106/220] Compiling OrderedCollections OrderedDictionary+Elements.SubSequence.swift
[107/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra isStrictSubset.swift
[108/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra isStrictSuperset.swift
[109/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra isSubset.swift
[110/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra isSuperset.swift
[111/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra subtract.swift
[112/220] Compiling OrderedCollections OrderedSet+Partial SetAlgebra subtracting.swift
[118/220] Compiling OrderedCollections _HashTable.swift
[119/220] Compiling OrderedCollections OrderedSet+Hashable.swift
[120/220] Compiling OrderedCollections OrderedSet+Initializers.swift
[121/220] Compiling OrderedCollections OrderedSet+Insertions.swift
[122/220] Compiling OrderedCollections OrderedSet+Invariants.swift
[123/220] Compiling OrderedCollections OrderedSet+Partial MutableCollection.swift
[124/220] Compiling OrderedCollections OrderedSet+Partial RangeReplaceableCollection.swift
[127/220] Compiling OrderedCollections _HashTable+Bucket.swift
[128/220] Compiling OrderedCollections _HashTable+BucketIterator.swift
[135/220] Compiling OrderedCollections OrderedDictionary+Partial MutableCollection.swift
[136/220] Compiling OrderedCollections OrderedDictionary+Partial RangeReplaceableCollection.swift
[137/220] Compiling OrderedCollections OrderedDictionary+Sendable.swift
[138/220] Compiling OrderedCollections OrderedDictionary+Sequence.swift
[139/220] Compiling OrderedCollections OrderedDictionary+Values.swift
[140/220] Compiling OrderedCollections OrderedDictionary.swift
[173/220] Emitting module DequeModule
[195/220] Compiling OrderedCollections OrderedSet+SubSequence.swift
[196/220] Compiling OrderedCollections OrderedSet+Testing.swift
[197/220] Compiling OrderedCollections OrderedSet+UnorderedView.swift
[198/220] Compiling OrderedCollections OrderedSet+UnstableInternals.swift
[199/220] Compiling OrderedCollections OrderedSet.swift
[200/220] Compiling OrderedCollections _UnsafeBitset.swift
[207/220] Emitting module OrderedCollections
[209/320] Compiling VexilMacros PatternBindingSyntax.swift
[210/320] Compiling VexilMacros String+Snakecase.swift
[211/320] Compiling VexilMacros SimpleVariables.swift
[212/320] Compiling AsyncAlgorithms AsyncAdjacentPairsSequence.swift
[213/320] Compiling AsyncAlgorithms AsyncBufferedByteIterator.swift
[214/320] Compiling AsyncAlgorithms AsyncChain2Sequence.swift
[215/320] Compiling AsyncAlgorithms AsyncChain3Sequence.swift
[216/320] Compiling AsyncAlgorithms AsyncChunkedByGroupSequence.swift
[217/320] Compiling AsyncAlgorithms AsyncChunkedOnProjectionSequence.swift
[218/325] Compiling AsyncAlgorithms Locking.swift
[219/325] Compiling AsyncAlgorithms AsyncMerge2Sequence.swift
[220/325] Compiling AsyncAlgorithms AsyncMerge3Sequence.swift
[221/325] Compiling AsyncAlgorithms MergeStateMachine.swift
[222/325] Compiling AsyncAlgorithms MergeStorage.swift
[223/325] Compiling AsyncAlgorithms AsyncThrottleSequence.swift
[224/325] Compiling AsyncAlgorithms AsyncThrowingExclusiveReductionsSequence.swift
[225/325] Compiling AsyncAlgorithms AsyncCombineLatest2Sequence.swift
[226/325] Compiling AsyncAlgorithms AsyncCombineLatest3Sequence.swift
[227/325] Compiling AsyncAlgorithms CombineLatestStateMachine.swift
[228/325] Compiling AsyncAlgorithms AsyncInterspersedSequence.swift
[234/325] Compiling AsyncAlgorithms CombineLatestStorage.swift
[235/325] Compiling AsyncAlgorithms AsyncDebounceSequence.swift
[236/325] Compiling AsyncAlgorithms DebounceStateMachine.swift
[237/325] Compiling AsyncAlgorithms DebounceStorage.swift
[238/325] Compiling AsyncAlgorithms Dictionary.swift
[239/325] Compiling AsyncAlgorithms _TinyArray.swift
[240/330] Compiling AsyncAlgorithms AsyncChunksOfCountOrSignalSequence.swift
[241/330] Compiling AsyncAlgorithms AsyncChunksOfCountSequence.swift
[242/330] Compiling AsyncAlgorithms AsyncCompactedSequence.swift
[243/330] Compiling AsyncAlgorithms AsyncExclusiveReductionsSequence.swift
[244/330] Compiling AsyncAlgorithms AsyncInclusiveReductionsSequence.swift
[245/330] Emitting module AsyncAlgorithms
[251/330] Compiling AsyncAlgorithms AsyncJoinedBySeparatorSequence.swift
[252/330] Compiling AsyncAlgorithms AsyncThrowingInclusiveReductionsSequence.swift
[253/330] Compiling AsyncAlgorithms AsyncTimerSequence.swift
[254/330] Compiling AsyncAlgorithms AsyncBufferSequence.swift
[255/330] Compiling AsyncAlgorithms BoundedBufferStateMachine.swift
[256/330] Compiling AsyncAlgorithms BoundedBufferStorage.swift
[257/330] Compiling AsyncAlgorithms UnboundedBufferStateMachine.swift
[258/330] Emitting module AsyncAlgorithms
[265/330] Compiling AsyncAlgorithms AsyncJoinedSequence.swift
[266/330] Compiling AsyncAlgorithms AsyncRemoveDuplicatesSequence.swift
[267/330] Compiling AsyncAlgorithms AsyncShareSequence.swift
[268/330] Compiling AsyncAlgorithms AsyncSyncSequence.swift
[281/330] Compiling AsyncAlgorithms UnboundedBufferStorage.swift
[282/330] Compiling AsyncAlgorithms AsyncChannel.swift
[283/330] Compiling AsyncAlgorithms AsyncThrowingChannel.swift
[284/330] Compiling AsyncAlgorithms ChannelStateMachine.swift
[285/330] Compiling AsyncAlgorithms ChannelStorage.swift
[286/330] Compiling AsyncAlgorithms UnsafeTransfer.swift
[287/330] Compiling AsyncAlgorithms AsyncZip2Sequence.swift
[288/330] Compiling AsyncAlgorithms AsyncZip3Sequence.swift
[289/330] Compiling AsyncAlgorithms ZipStateMachine.swift
[290/330] Compiling AsyncAlgorithms ZipStorage.swift
[291/330] Compiling VexilMacros AttributeArgument.swift
[292/330] Compiling VexilMacros Plugin.swift
[293/330] Compiling VexilMacros FlagMacro.swift
[294/330] Compiling VexilMacros FlagGroupMacro.swift
[295/330] Compiling VexilMacros DisplayName.swift
[296/330] Emitting module VexilMacros
/Users/admin/builder/spi-builder-workspace/Sources/VexilMacros/FlagContainerMacro.swift:21:1: warning: deprecated default implementation is used to satisfy static method 'expansion(of:providingMembersOf:conformingTo:in:)' required by protocol 'MemberMacro': `MemberMacro` conformance should implement the `expansion` function that takes a `conformingTo` parameter [#DeprecatedDeclaration]
 19 | public enum FlagContainerMacro {}
 20 |
 21 | extension FlagContainerMacro: MemberMacro {
    | `- warning: deprecated default implementation is used to satisfy static method 'expansion(of:providingMembersOf:conformingTo:in:)' required by protocol 'MemberMacro': `MemberMacro` conformance should implement the `expansion` function that takes a `conformingTo` parameter [#DeprecatedDeclaration]
 22 |
 23 |     public static func expansion(
SwiftSyntaxMacros.MemberMacro.expansion:3:22: note: 'expansion(of:providingMembersOf:conformingTo:in:)' declared here
1 | protocol MemberMacro {
2 | @available(*, deprecated, message: "`MemberMacro` conformance should implement the `expansion` function that takes a `conformingTo` parameter")
3 |   public static func expansion(of node: SwiftSyntax.AttributeSyntax, providingMembersOf declaration: some SwiftSyntax.DeclGroupSyntax, conformingTo protocols: [SwiftSyntax.TypeSyntax], in context: some SwiftSyntaxMacros.MacroExpansionContext) throws -> [SwiftSyntax.DeclSyntax]}
  |                      `- note: 'expansion(of:providingMembersOf:conformingTo:in:)' declared here
4 |
SwiftSyntaxMacros.MemberMacro.expansion:2:13: note: requirement 'expansion(of:providingMembersOf:conformingTo:in:)' declared here
1 | protocol MemberMacro {
2 | static func expansion(of node: SwiftSyntax.AttributeSyntax, providingMembersOf declaration: some SwiftSyntax.DeclGroupSyntax, conformingTo protocols: [SwiftSyntax.TypeSyntax], in context: some SwiftSyntaxMacros.MacroExpansionContext) throws -> [SwiftSyntax.DeclSyntax]}
  |             `- note: requirement 'expansion(of:providingMembersOf:conformingTo:in:)' declared here
3 |
[#DeprecatedDeclaration]: <https://docs.swift.org/compiler/documentation/diagnostics/deprecated-declaration>
[297/330] Compiling VexilMacros FlagContainerMacro.swift
/Users/admin/builder/spi-builder-workspace/Sources/VexilMacros/FlagContainerMacro.swift:21:1: warning: deprecated default implementation is used to satisfy static method 'expansion(of:providingMembersOf:conformingTo:in:)' required by protocol 'MemberMacro': `MemberMacro` conformance should implement the `expansion` function that takes a `conformingTo` parameter [#DeprecatedDeclaration]
 19 | public enum FlagContainerMacro {}
 20 |
 21 | extension FlagContainerMacro: MemberMacro {
    | `- warning: deprecated default implementation is used to satisfy static method 'expansion(of:providingMembersOf:conformingTo:in:)' required by protocol 'MemberMacro': `MemberMacro` conformance should implement the `expansion` function that takes a `conformingTo` parameter [#DeprecatedDeclaration]
 22 |
 23 |     public static func expansion(
SwiftSyntaxMacros.MemberMacro.expansion:3:22: note: 'expansion(of:providingMembersOf:conformingTo:in:)' declared here
1 | protocol MemberMacro {
2 | @available(*, deprecated, message: "`MemberMacro` conformance should implement the `expansion` function that takes a `conformingTo` parameter")
3 |   public static func expansion(of node: SwiftSyntax.AttributeSyntax, providingMembersOf declaration: some SwiftSyntax.DeclGroupSyntax, conformingTo protocols: [SwiftSyntax.TypeSyntax], in context: some SwiftSyntaxMacros.MacroExpansionContext) throws -> [SwiftSyntax.DeclSyntax]}
  |                      `- note: 'expansion(of:providingMembersOf:conformingTo:in:)' declared here
4 |
SwiftSyntaxMacros.MemberMacro.expansion:2:13: note: requirement 'expansion(of:providingMembersOf:conformingTo:in:)' declared here
1 | protocol MemberMacro {
2 | static func expansion(of node: SwiftSyntax.AttributeSyntax, providingMembersOf declaration: some SwiftSyntax.DeclGroupSyntax, conformingTo protocols: [SwiftSyntax.TypeSyntax], in context: some SwiftSyntaxMacros.MacroExpansionContext) throws -> [SwiftSyntax.DeclSyntax]}
  |             `- note: requirement 'expansion(of:providingMembersOf:conformingTo:in:)' declared here
3 |
[#DeprecatedDeclaration]: <https://docs.swift.org/compiler/documentation/diagnostics/deprecated-declaration>
[297/330] Write Objects.LinkFileList
[305/330] Compiling AsyncAlgorithms MultiProducerSingleConsumerAsyncChannel+Internal.swift
[306/330] Compiling AsyncAlgorithms MultiProducerSingleConsumerAsyncChannel.swift
[307/330] Compiling AsyncAlgorithms RangeReplaceableCollection.swift
[308/330] Compiling AsyncAlgorithms Rethrow.swift
[309/330] Compiling AsyncAlgorithms SetAlgebra.swift
[329/330] Linking VexilMacros-tool
[331/400] Compiling Vexil Container.swift
[332/400] Compiling Vexil DisplayOptions.swift
[333/400] Compiling Vexil Flag.swift
[334/400] Compiling Vexil FlagValueDictionary.swift
[335/403] Compiling Vexil Snapshot.swift
[336/403] Compiling Vexil SnapshotBuilder.swift
[337/403] Compiling Vexil BoxedFlagValue+NSObject.swift
[338/403] Compiling Vexil FlagValueDictionary+FlagValueSource.swift
[339/403] Compiling Vexil BoxedFlagValue+Codable.swift
[340/403] Compiling Vexil CollectionDifference.Change+Element.swift
[341/403] Compiling Vexil FlagChangeStream.swift
[342/403] Compiling Vexil Snapshot.swift
[343/403] Compiling Vexil SnapshotBuilder.swift
[344/403] Compiling Vexil BoxedFlagValue+NSObject.swift
[345/403] Compiling Vexil FlagValueDictionary+FlagValueSource.swift
[346/403] Compiling Vexil FlagValueDictionary.swift
[347/403] Compiling Vexil FlagValueSource.swift
[348/403] Compiling Vexil StreamManager.swift
[349/403] Compiling Vexil AsyncCurrentValue.swift
[350/403] Emitting module Vexil
[351/406] Compiling Vexil Observing.swift
[352/406] Compiling Vexil Pole+Observability.swift
[353/406] Compiling Vexil Pole.swift
[354/406] Compiling Vexil Configuration.swift
[359/406] Emitting module Vexil
[360/406] Compiling Vexil BoxedFlagValue+Codable.swift
[361/406] Compiling Vexil CollectionDifference.Change+Element.swift
[362/406] Compiling Vexil FlagChangeStream.swift
[363/406] Compiling Vexil FlagWigwag.swift
[371/406] Compiling Vexil FlagDescriber.swift
[372/406] Compiling Vexil FlagRemover.swift
[373/406] Compiling Vexil FlagSetter.swift
[384/406] Compiling Vexil Lock.swift
[385/406] Compiling Vexil Value.swift
[386/406] Compiling Vexil Visitor.swift
[387/406] Compiling Vexil FlagValueSource.swift
[389/406] Compiling Vexil FlagValueSourceCoordinator.swift
[391/406] Compiling Vexil NSUbiquitousKeyValueStore+FlagValueSource.swift
[394/406] Compiling Vexil MutableFlagContainer.swift
[407/427] Compiling Vexillographer FlagPicker+Bool.swift
[408/427] Compiling Vexillographer FlagPicker+CaseIterable.swift
[409/427] Compiling Vexillographer FlagPicker.swift
[410/429] Emitting module Vexillographer
[411/429] Compiling Vexillographer OptionalProtocol.swift
[412/429] Compiling Vexillographer Vexillographer.swift
[413/429] Compiling Vexillographer FlagTextField+FloatingPoint.swift
[414/429] Compiling Vexillographer FlagTextField+Integer.swift
[415/429] Compiling Vexillographer FlagControl.swift
[416/429] Compiling Vexillographer FlagControlConfiguration.swift
[417/429] Compiling Vexillographer FlagDetail.swift
[418/429] Compiling Vexillographer FlagToggle.swift
[419/429] Compiling Vexillographer RowContent.swift
[420/429] Compiling Vexillographer FlagPoleItemGroup.swift
[421/429] Compiling Vexillographer FlagPoleVisitor.swift
[422/429] Compiling Vexillographer FlagTextField+String.swift
[423/429] Compiling Vexillographer FlagTextField.swift
[424/429] Compiling Vexillographer FlagPoleContext.swift
[425/429] Compiling Vexillographer FlagPoleItem.swift
[426/429] Compiling Vexillographer FlagGroupItem.swift
[427/429] Compiling Vexillographer FlagItem.swift
[428/429] Compiling Vexillographer View+FlagControlStyle.swift
[429/429] Compiling Vexillographer View+FlagPole.swift
Build complete! (16.98s)
Build complete.
{
  "dependencies" : [
    {
      "identity" : "swift-async-algorithms",
      "requirement" : {
        "range" : [
          {
            "lower_bound" : "1.0.0",
            "upper_bound" : "2.0.0"
          }
        ]
      },
      "type" : "sourceControl",
      "url" : "https://github.com/apple/swift-async-algorithms.git"
    },
    {
      "identity" : "swiftformat",
      "requirement" : {
        "range" : [
          {
            "lower_bound" : "0.54.1",
            "upper_bound" : "1.0.0"
          }
        ]
      },
      "type" : "sourceControl",
      "url" : "https://github.com/nicklockwood/SwiftFormat.git"
    },
    {
      "identity" : "swift-syntax",
      "requirement" : {
        "range" : [
          {
            "lower_bound" : "600.0.0",
            "upper_bound" : "603.0.0"
          }
        ]
      },
      "type" : "sourceControl",
      "url" : "https://github.com/swiftlang/swift-syntax.git"
    }
  ],
  "manifest_display_name" : "Vexil",
  "name" : "Vexil",
  "path" : "/Users/admin/builder/spi-builder-workspace",
  "platforms" : [
    {
      "name" : "ios",
      "version" : "15.0"
    },
    {
      "name" : "macos",
      "version" : "12.0"
    },
    {
      "name" : "tvos",
      "version" : "15.0"
    },
    {
      "name" : "watchos",
      "version" : "8.0"
    }
  ],
  "products" : [
    {
      "name" : "Vexil",
      "targets" : [
        "Vexil"
      ],
      "type" : {
        "library" : [
          "automatic"
        ]
      }
    },
    {
      "name" : "Vexillographer",
      "targets" : [
        "Vexillographer"
      ],
      "type" : {
        "library" : [
          "automatic"
        ]
      }
    },
    {
      "name" : "VexilMacros",
      "targets" : [
        "VexilMacros"
      ],
      "type" : {
        "macro" : null
      }
    }
  ],
  "swift_languages_versions" : [
    "6"
  ],
  "targets" : [
    {
      "c99name" : "Vexillographer",
      "module_type" : "SwiftTarget",
      "name" : "Vexillographer",
      "path" : "Sources/Vexillographer",
      "product_memberships" : [
        "Vexillographer"
      ],
      "sources" : [
        "FlagControl/FlagControl.swift",
        "FlagControl/FlagControlConfiguration.swift",
        "FlagControl/FlagDetail.swift",
        "FlagControl/FlagPicker+Bool.swift",
        "FlagControl/FlagPicker+CaseIterable.swift",
        "FlagControl/FlagPicker.swift",
        "FlagControl/FlagTextField+FloatingPoint.swift",
        "FlagControl/FlagTextField+Integer.swift",
        "FlagControl/FlagTextField+String.swift",
        "FlagControl/FlagTextField.swift",
        "FlagControl/FlagToggle.swift",
        "FlagControl/RowContent.swift",
        "FlagPole/FlagGroupItem.swift",
        "FlagPole/FlagItem.swift",
        "FlagPole/FlagPoleContext.swift",
        "FlagPole/FlagPoleItem.swift",
        "FlagPole/FlagPoleItemGroup.swift",
        "FlagPole/FlagPoleVisitor.swift",
        "Utilities/OptionalProtocol.swift",
        "Vexillographer.swift",
        "View+FlagControlStyle.swift",
        "View+FlagPole.swift"
      ],
      "target_dependencies" : [
        "Vexil"
      ],
      "type" : "library"
    },
    {
      "c99name" : "VexilTests",
      "module_type" : "SwiftTarget",
      "name" : "VexilTests",
      "path" : "Tests/VexilTests",
      "sources" : [
        "BoxedFlagValueDecodingTests.swift",
        "BoxedFlagValueEncodingTests.swift",
        "EquatableTests.swift",
        "FlagDetailTests.swift",
        "FlagPoleTests.swift",
        "FlagValueBoxingTests.swift",
        "FlagValueCompilationTests.swift",
        "FlagValueDictionaryTests.swift",
        "FlagValueSourceTests.swift",
        "FlagValueUnboxingTests.swift",
        "KeyEncodingTests.swift",
        "PublisherTests.swift",
        "SnapshotTests.swift",
        "UserDefaultPublisherTests.swift",
        "UserDefaultsDecodingTests.swift",
        "UserDefaultsEncodingTests.swift",
        "Utilities/Tags.swift",
        "Utilities/TestRunner.swift",
        "VisitorTests.swift"
      ],
      "target_dependencies" : [
        "Vexil"
      ],
      "type" : "test"
    },
    {
      "c99name" : "VexilMacros",
      "module_type" : "SwiftTarget",
      "name" : "VexilMacros",
      "path" : "Sources/VexilMacros",
      "product_dependencies" : [
        "SwiftCompilerPlugin",
        "SwiftSyntax",
        "SwiftSyntaxBuilder",
        "SwiftSyntaxMacros"
      ],
      "product_memberships" : [
        "Vexil",
        "Vexillographer",
        "VexilMacros"
      ],
      "sources" : [
        "FlagContainerMacro.swift",
        "FlagGroupMacro.swift",
        "FlagMacro.swift",
        "Plugin.swift",
        "Utilities/AttributeArgument.swift",
        "Utilities/DisplayName.swift",
        "Utilities/PatternBindingSyntax.swift",
        "Utilities/SimpleVariables.swift",
        "Utilities/String+Snakecase.swift"
      ],
      "type" : "macro"
    },
    {
      "c99name" : "VexilMacroTests",
      "module_type" : "SwiftTarget",
      "name" : "VexilMacroTests",
      "path" : "Tests/VexilMacroTests",
      "product_dependencies" : [
        "SwiftSyntaxMacrosTestSupport"
      ],
      "sources" : [
        "EquatableFlagContainerMacroTests.swift",
        "FlagContainerMacroTests.swift",
        "FlagGroupMacroTests.swift",
        "FlagMacroTests.swift"
      ],
      "target_dependencies" : [
        "VexilMacros"
      ],
      "type" : "test"
    },
    {
      "c99name" : "Vexil",
      "module_type" : "SwiftTarget",
      "name" : "Vexil",
      "path" : "Sources/Vexil",
      "product_dependencies" : [
        "AsyncAlgorithms"
      ],
      "product_memberships" : [
        "Vexil",
        "Vexillographer"
      ],
      "sources" : [
        "Configuration.swift",
        "Container.swift",
        "DisplayOptions.swift",
        "Flag.swift",
        "Group.swift",
        "KeyPath.swift",
        "Lookup.swift",
        "Observability/FlagGroupWigwag.swift",
        "Observability/FlagWigwag.swift",
        "Observability/Observing.swift",
        "Pole+Observability.swift",
        "Pole.swift",
        "Snapshots/MutableFlagContainer.swift",
        "Snapshots/Snapshot+Extensions.swift",
        "Snapshots/Snapshot+FlagValueSource.swift",
        "Snapshots/Snapshot+Lookup.swift",
        "Snapshots/Snapshot.swift",
        "Snapshots/SnapshotBuilder.swift",
        "Sources/BoxedFlagValue+NSObject.swift",
        "Sources/FlagValueDictionary+FlagValueSource.swift",
        "Sources/FlagValueDictionary.swift",
        "Sources/FlagValueSource.swift",
        "Sources/FlagValueSourceCoordinator.swift",
        "Sources/NSUbiquitousKeyValueStore+FlagValueSource.swift",
        "Sources/NonSendableFlagValueSource.swift",
        "Sources/UserDefaults+FlagValueSource.swift",
        "StreamManager.swift",
        "Utilities/AsyncCurrentValue.swift",
        "Utilities/BoxedFlagValue+Codable.swift",
        "Utilities/CollectionDifference.Change+Element.swift",
        "Utilities/FlagChangeStream.swift",
        "Utilities/Lock.swift",
        "Value.swift",
        "Visitor.swift",
        "Visitors/FlagDescriber.swift",
        "Visitors/FlagRemover.swift",
        "Visitors/FlagSetter.swift"
      ],
      "target_dependencies" : [
        "VexilMacros"
      ],
      "type" : "library"
    }
  ],
  "tools_version" : "6.1"
}
✅  Doc result (pending) reported
========================================
GenerateDocs
========================================
Generating docs at path:  $PWD/.docs/unsignedapps/vexil/main
Repository:               unsignedapps/Vexil
Swift version used:       6.2
Target:                   Vexil
Extracting symbol information for 'Vexil'...
Finished extracting symbol information for 'Vexil'. (4.20s)
Building documentation for 'Vexil'...
warning: External name 'at' used to document parameter
   --> ../Pole.swift:318:13-318:15
316 |     /// - Parameters:
317 |     ///   - snapshot:       The `Snapshot` to be inserted
318 +     ///   - at:             The index at which to insert the `Snapshot`.
    |             ╰─suggestion: Replace 'at' with 'index'
319 |     ///
320 |     public func insert(snapshot: Snapshot<RootGroup>, at index: Array<any FlagValueSource>.Index) {
warning: External name 'to' used to document parameter
   --> ../Pole.swift:376:13-376:15
374 |     /// - Parameters:
375 |     ///   - snapshot:           The `Snapshot` to save to the source. Only the values included in the snapshot will be saved.
376 +     ///   - to:                 The `FlagValueSource` to save the snapshot to.
    |             ╰─suggestion: Replace 'to' with 'source'
377 |     ///
378 |     public func save(snapshot: Snapshot<RootGroup>, to source: some FlagValueSource) throws {
warning: 'valuesDidChange(keys:)-7y64r' doesn't exist at '/Vexil/FlagValueSource'
  --> CustomSources.md:42:261-42:289
40 | ## Real-time flag value publishing
41 |
42 + If you're using the `Publisher`s provided by Vexil though, you'll want to make sure your custom source also notifies the ``FlagPole`` when it is changed. To do that there is a simple additional function in the protocol you need to implement: ``FlagValueSource/valuesDidChange(keys:)-7y64r``.
   |                                                                                                                                                                                                                                                                     ╰─suggestion: Replace 'valuesDidChange(keys:)-7y64r' with 'flagValueChanges(keyPathMapper:)'
43 |
44 | (At the time of writing this document, Combine is still not available on Linux, so we take care in our implementation. These conditional compilation steps are omitted from the examples for brevity.)
warning: 'FlagGroup' doesn't exist at '/Vexil/DefiningFlags'
 --> DefiningFlags.md:4:98-4:107
2 | # Defining Flags
3 |
4 + Defining Flags is the cornerstone of Vexil. Learn how to structure your ``FlagContainer``, use ``FlagGroup``s and ``Flag``s of various types.
  |                                                                                                  ╰─suggestion: Replace 'FlagGroup' with 'Flag-Groups'
5 |
6 | ## Overview
warning: 'Flag' doesn't exist at '/Vexil/DefiningFlags'
 --> DefiningFlags.md:4:117-4:121
2 | # Defining Flags
3 |
4 + Defining Flags is the cornerstone of Vexil. Learn how to structure your ``FlagContainer``, use ``FlagGroup``s and ``Flag``s of various types.
  |                                                                                                                     ├─suggestion: Replace 'Flag' with 'Flag-types'
  |                                                                                                                     ╰─suggestion: Replace 'Flag' with 'Flag-Groups'
5 |
6 | ## Overview
warning: 'FlagPoleDiagnostic' doesn't exist at '/Vexil/Diagnostics'
  --> Diagnostics.md:58:5-58:23
56 | ### Diagnostics
57 |
58 + - ``FlagPoleDiagnostic``
   |     ├─suggestion: Replace 'FlagPoleDiagnostic' with 'Diagnostics'
   |     ╰─suggestion: Replace 'FlagPoleDiagnostic' with 'Real-time-diagnostics'
59 | - ``FlagPole/makeDiagnostics()``
60 | - ``FlagPole/makeDiagnosticsPublisher()``
warning: 'makeDiagnostics()' doesn't exist at '/Vexil/FlagPole'
  --> Diagnostics.md:59:14-59:31
57 |
58 | - ``FlagPoleDiagnostic``
59 + - ``FlagPole/makeDiagnostics()``
60 | - ``FlagPole/makeDiagnosticsPublisher()``
61 | - ``Snapshot/makeDiagnostics()``
warning: 'makeDiagnosticsPublisher()' doesn't exist at '/Vexil/FlagPole'
  --> Diagnostics.md:60:14-60:40
58 | - ``FlagPoleDiagnostic``
59 | - ``FlagPole/makeDiagnostics()``
60 + - ``FlagPole/makeDiagnosticsPublisher()``
61 | - ``Snapshot/makeDiagnostics()``
warning: 'makeDiagnostics()' doesn't exist at '/Vexil/Snapshot'
  --> Diagnostics.md:61:14-61:31
59 | - ``FlagPole/makeDiagnostics()``
60 | - ``FlagPole/makeDiagnosticsPublisher()``
61 + - ``Snapshot/makeDiagnostics()``
warning: 'FlagGroup' doesn't exist at '/Vexil/FlagKeys'
  --> FlagKeys.md:9:129-9:138
7  | Lets be honest, any Feature Flag or Feature Toggle platform is just a glorified Key-Value store, and all Vexil does is map string-based keys into a strongly-typed hierarchy and provide a (hopefully) nice developer experience.
8  |
9  + It's very important then when working with different ``FlagValueSource``s that you know how Vexil maps the ``FlagContainer``, ``FlagGroup`` and ``Flag``s into something that can work with any key-value store.
   |                                                                                                                                 ├─suggestion: Replace 'FlagGroup' with 'FlagGroup-Overrides'
   |                                                                                                                                 ╰─suggestion: Replace 'FlagGroup' with 'Skipping-FlagGroups'
10 |
11 | ## FlagPole Configuration
warning: 'Flag' doesn't exist at '/Vexil/FlagKeys'
  --> FlagKeys.md:9:147-9:151
7  | Lets be honest, any Feature Flag or Feature Toggle platform is just a glorified Key-Value store, and all Vexil does is map string-based keys into a strongly-typed hierarchy and provide a (hopefully) nice developer experience.
8  |
9  + It's very important then when working with different ``FlagValueSource``s that you know how Vexil maps the ``FlagContainer``, ``FlagGroup`` and ``Flag``s into something that can work with any key-value store.
   |                                                                                                                                                   ╰─suggestion: Replace 'Flag' with 'Flag-Key-Overrides'
10 |
11 | ## FlagPole Configuration
warning: 'Flag' doesn't exist at '/Vexil/FlagKeys'
  --> FlagKeys.md:24:29-24:33
22 | Vexil supports a number of different strategies to encoding keys. The default approach is the `kebabcase` encoding with period (`.`) separators.
23 |
24 + You can find the key of a ``Flag`` at any time using its ``Flag/key`` property.
   |                             ╰─suggestion: Replace 'Flag' with 'Flag-Key-Overrides'
25 |
26 | #### Kebab-case encoding
warning: 'Flag' doesn't exist at '/Vexil/FlagKeys'
  --> FlagKeys.md:24:60-24:64
22 | Vexil supports a number of different strategies to encoding keys. The default approach is the `kebabcase` encoding with period (`.`) separators.
23 |
24 + You can find the key of a ``Flag`` at any time using its ``Flag/key`` property.
   |                                                            ╰─suggestion: Replace 'Flag' with 'Flag-Key-Overrides'
25 |
26 | #### Kebab-case encoding
warning: 'Flag' doesn't exist at '/Vexil/FlagKeys'
  --> FlagKeys.md:73:111-73:115
71 | ## Flag Key Overrides
72 |
73 + Sometimes though you want to override how a specific flag calculates its key. Vexil allows you to pass in a ``Flag/CodingKeyStrategy`` when you declare your ``Flag`` to alter how its key is calculated:
   |                                                                                                               ╰─suggestion: Replace 'Flag' with 'Flag-Key-Overrides'
74 |
75 | ```swift
warning: 'Flag' doesn't exist at '/Vexil/FlagKeys'
  --> FlagKeys.md:73:160-73:164
71 | ## Flag Key Overrides
72 |
73 + Sometimes though you want to override how a specific flag calculates its key. Vexil allows you to pass in a ``Flag/CodingKeyStrategy`` when you declare your ``Flag`` to alter how its key is calculated:
   |                                                                                                                                                                ╰─suggestion: Replace 'Flag' with 'Flag-Key-Overrides'
74 |
75 | ```swift
warning: 'Flag' doesn't exist at '/Vexil/FlagKeys'
  --> FlagKeys.md:86:84-86:88
84 | ### Custom Key
85 |
86 + You can also go for a manually specified key instead of a calculated one using a ``Flag/CodingKeyStrategy`` of `.customKey("my-key")`:
   |                                                                                    ╰─suggestion: Replace 'Flag' with 'Flag-Key-Overrides'
87 |
88 | ```swift
warning: 'Flag' doesn't exist at '/Vexil/FlagKeys'
  --> FlagKeys.md:97:278-97:282
95 | ### Custom Key Path
96 |
97 + But sometimes your ``FlagValueSource`` doesn't play nice, or the people naming flags in the backend don't provide the same structure that you want your local flags to be in. You can instead set a manual key path. In this case the ``FlagPole`` will ignore the location of the ``Flag`` in the flag structure and will just use the key you specify.
   |                                                                                                                                                                                                                                                                                      ╰─suggestion: Replace 'Flag' with 'Flag-Key-Overrides'
98 |
99 | ```swift
warning: 'FlagGroup' doesn't exist at '/Vexil/FlagKeys'
   --> FlagKeys.md:108:11-108:20
106 | ## FlagGroup Overrides
107 |
108 + While a ``FlagGroup`` doesn't have an explicit key of its own, it does form part of the calculated key. For example, if we declared our `MyFlags` structure as:
    |           ├─suggestion: Replace 'FlagGroup' with 'FlagGroup-Overrides'
    |           ╰─suggestion: Replace 'FlagGroup' with 'Skipping-FlagGroups'
109 |
110 | ```swift
warning: 'Flag' doesn't exist at '/Vexil/FlagKeys'
   --> FlagKeys.md:121:20-121:24
119 | Then `"subgroup"` would form the first part of the key as calculated in the examples above.
120 |
121 + Similarly to the ``Flag``s, we can customise the calculation of the ``FlagGroup``s key by passing in a custom ``FlagGroup/CodingKeyStrategy``.
    |                    ╰─suggestion: Replace 'Flag' with 'Flag-Key-Overrides'
122 |
123 | ``FlagGroup/CodingKeyStrategy`` supports most of the same basic options as the ``Flag`` above (eg, `.kebabcase`, `.snakecase`, and `.customKey(String)`), but it does not support a `.customKeyPath(String)`, because it does not have its own key calculated.
warning: 'FlagGroup' doesn't exist at '/Vexil/FlagKeys'
   --> FlagKeys.md:121:71-121:80
119 | Then `"subgroup"` would form the first part of the key as calculated in the examples above.
120 |
121 + Similarly to the ``Flag``s, we can customise the calculation of the ``FlagGroup``s key by passing in a custom ``FlagGroup/CodingKeyStrategy``.
    |                                                                       ├─suggestion: Replace 'FlagGroup' with 'FlagGroup-Overrides'
    |                                                                       ╰─suggestion: Replace 'FlagGroup' with 'Skipping-FlagGroups'
122 |
123 | ``FlagGroup/CodingKeyStrategy`` supports most of the same basic options as the ``Flag`` above (eg, `.kebabcase`, `.snakecase`, and `.customKey(String)`), but it does not support a `.customKeyPath(String)`, because it does not have its own key calculated.
warning: 'FlagGroup' doesn't exist at '/Vexil/FlagKeys'
   --> FlagKeys.md:121:113-121:122
119 | Then `"subgroup"` would form the first part of the key as calculated in the examples above.
120 |
121 + Similarly to the ``Flag``s, we can customise the calculation of the ``FlagGroup``s key by passing in a custom ``FlagGroup/CodingKeyStrategy``.
    |                                                                                                                 ├─suggestion: Replace 'FlagGroup' with 'FlagGroup-Overrides'
    |                                                                                                                 ╰─suggestion: Replace 'FlagGroup' with 'Skipping-FlagGroups'
122 |
123 | ``FlagGroup/CodingKeyStrategy`` supports most of the same basic options as the ``Flag`` above (eg, `.kebabcase`, `.snakecase`, and `.customKey(String)`), but it does not support a `.customKeyPath(String)`, because it does not have its own key calculated.
warning: 'FlagGroup' doesn't exist at '/Vexil/FlagKeys'
   --> FlagKeys.md:123:3-123:12
121 | Similarly to the ``Flag``s, we can customise the calculation of the ``FlagGroup``s key by passing in a custom ``FlagGroup/CodingKeyStrategy``.
122 |
123 + ``FlagGroup/CodingKeyStrategy`` supports most of the same basic options as the ``Flag`` above (eg, `.kebabcase`, `.snakecase`, and `.customKey(String)`), but it does not support a `.customKeyPath(String)`, because it does not have its own key calculated.
    |   ├─suggestion: Replace 'FlagGroup' with 'FlagGroup-Overrides'
    |   ╰─suggestion: Replace 'FlagGroup' with 'Skipping-FlagGroups'
124 |
125 | ### Skipping FlagGroups
warning: 'Flag' doesn't exist at '/Vexil/FlagKeys'
   --> FlagKeys.md:123:82-123:86
121 | Similarly to the ``Flag``s, we can customise the calculation of the ``FlagGroup``s key by passing in a custom ``FlagGroup/CodingKeyStrategy``.
122 |
123 + ``FlagGroup/CodingKeyStrategy`` supports most of the same basic options as the ``Flag`` above (eg, `.kebabcase`, `.snakecase`, and `.customKey(String)`), but it does not support a `.customKeyPath(String)`, because it does not have its own key calculated.
    |                                                                                  ╰─suggestion: Replace 'Flag' with 'Flag-Key-Overrides'
124 |
125 | ### Skipping FlagGroups
warning: 'FlagGroup' doesn't exist at '/Vexil/FlagKeys'
   --> FlagKeys.md:127:33-127:42
125 | ### Skipping FlagGroups
126 |
127 + It does support an additional ``FlagGroup/CodingKeyStrategy`` though: `.skip`. Which will ignore that ``FlagGroup``s key in the calculation:
    |                                 ├─suggestion: Replace 'FlagGroup' with 'FlagGroup-Overrides'
    |                                 ╰─suggestion: Replace 'FlagGroup' with 'Skipping-FlagGroups'
128 |
129 | ```swift
warning: 'FlagGroup' doesn't exist at '/Vexil/FlagKeys'
   --> FlagKeys.md:127:105-127:114
125 | ### Skipping FlagGroups
126 |
127 + It does support an additional ``FlagGroup/CodingKeyStrategy`` though: `.skip`. Which will ignore that ``FlagGroup``s key in the calculation:
    |                                                                                                         ├─suggestion: Replace 'FlagGroup' with 'FlagGroup-Overrides'
    |                                                                                                         ╰─suggestion: Replace 'FlagGroup' with 'Skipping-FlagGroups'
128 |
129 | ```swift
warning: 'Flag' doesn't exist at '/Vexil/FlagPublishing'
  --> FlagPublishing.md:46:33-46:37
44 | ```
45 |
46 + **Note:** If the type of your ``Flag`` also conforms to `Equatable`, the flag-specific publisher will emit the value only when it has changed (using `removeDuplicates()`). If your ``Flag`` does not conform to `Equatable` it will be unable to remove the duplicates and emit every time the ``FlagPole`` changes.
warning: 'Flag' doesn't exist at '/Vexil/FlagPublishing'
  --> FlagPublishing.md:46:183-46:187
44 | ```
45 |
46 + **Note:** If the type of your ``Flag`` also conforms to `Equatable`, the flag-specific publisher will emit the value only when it has changed (using `removeDuplicates()`). If your ``Flag`` does not conform to `Equatable` it will be unable to remove the duplicates and emit every time the ``FlagPole`` changes.
warning: 'Flag' doesn't exist at '/Vexil/Snapshots'
  --> Snapshots.md:55:180-55:184
53 | ### Empty snapshots
54 |
55 + When taking an empty snapshot, its internal dictionary is also empty, and the request for the Flag's value (when used as a ``FlagValueSource``) will be `nil`. If you access the ``Flag/wrappedValue`` property directly (eg. `flagPole.subgroup.myBooleanFlag`) it will return the flag's **default value**.
56 |
57 | Empty snapshots are typically used for mutating the ``FlagPole`` or a ``FlagValueSource``.
warning: 'Sources' is ambiguous at '/Vexil'
  --> Snapshots.md:81:69-81:76
79 | You can also take a snapshot of the current state of a ``FlagValueSource``. This is a great way to export flag values out of a source and into another. In fact the ``FlagPole/copyFlagValues(from:to:)`` method uses this to copy flag values from one ``FlagValueSource`` to another.
80 |
81 + Your ``FlagValueSource`` doesn't even need to be a part of the [flag hierarchy](<doc:Sources>).
   |                                                                            ├─suggestion: Insert '-article' for 'Flag Hierarchy'
   |                                                                            ╰─suggestion: Insert '-anchor' for 'Sources'
82 |
83 | ```swift
warning: 'Snapshots' is ambiguous at '/Vexil'
  --> Vexil.md:80:24-80:33
78 | ```
79 |
80 + For more info see <doc:Snapshots>.
   |                                 ├─suggestion: Insert '-anchor' for 'Snapshots'
   |                                 ╰─suggestion: Insert '-article' for 'Snapshots'
81 |
82 | ## Flag Value Sources
warning: 'Snapshots' is ambiguous at '/Vexil'
   --> Vexil.md:102:38-102:47
100 | Snapshots are implemented as a ``FlagValueSource``, so you can easily apply multiple snapshots in a prioritised order.
101 |
102 + Snapshots can do a lot. See our [Snapshots Guide](<doc:Snapshots>) for more.
    |                                               ├─suggestion: Insert '-anchor' for 'Snapshots'
    |                                               ╰─suggestion: Insert '-article' for 'Snapshots'
103 |
104 | ## Creating snapshots
warning: 'Sources' is ambiguous at '/Vexil'
   --> Vexil.md:144:8-144:15
142 | - ``VexilConfiguration``
143 | - <doc:Migration2-3>
144 + - <doc:Sources>
    |               ├─suggestion: Insert '-article' for 'Flag Hierarchy'
    |               ╰─suggestion: Insert '-anchor' for 'Sources'
145 | - <doc:FlagPublishing>
146 | - <doc:FlagKeys>
warning: 'Snapshots' is ambiguous at '/Vexil'
   --> Vexil.md:163:8-163:17
161 | ### Snapshots
162 |
163 + - <doc:Snapshots>
    |                 ├─suggestion: Insert '-anchor' for 'Snapshots'
    |                 ╰─suggestion: Insert '-article' for 'Snapshots'
164 | - ``Snapshot``
165 | - ``MutableFlagContainer``
warning: 'beginContainer(keyPath:container:)' doesn't exist at '/Vexil/FlagVisitor'
  --> ../Visitor.swift:21:76-21:110
19 | /// Walking always starts at a Container, and then walks the children of that container.
20 | /// When one of the children is a group, a call to ``beginGroup(keyPath:wigwag:)`` is made before
21 + /// descending into the group's container. That container will then call ``beginContainer(keyPath:container:)``
   |                                                                            ╰─suggestion: Replace 'beginContainer(keyPath:container:)' with 'beginContainer(keyPath:containerType:)'
22 | /// itself. You can use this to differentiate between the operations you are looking for.
23 | ///
warning: 'FlagGroup' doesn't exist at '/Vexil/FlagVisitor/beginGroup(keyPath:wigwag:)'
  --> ../Visitor.swift:86:51-86:60
84 |     func endContainer(keyPath: FlagKeyPath)
85 |
86 +     /// Called when about to descend into a new ``FlagGroup``
87 |     func beginGroup(keyPath: FlagKeyPath, wigwag: () -> FlagGroupWigwag<some FlagContainer>)
88 |
warning: 'FlagGroup' doesn't exist at '/Vexil/FlagVisitor/endGroup(keyPath:)'
  --> ../Visitor.swift:89:43-89:52
87 |     func beginGroup(keyPath: FlagKeyPath, wigwag: () -> FlagGroupWigwag<some FlagContainer>)
88 |
89 +     /// Called when finished visiting a ``FlagGroup``
90 |     func endGroup(keyPath: FlagKeyPath)
91 |
Finished building documentation for 'Vexil' (0.63s)
Generated documentation archive at:
  /Users/admin/builder/spi-builder-workspace/.docs/unsignedapps/vexil/main
Fetching https://github.com/swiftlang/swift-docc-plugin
[1/2158] Fetching swift-docc-plugin
Updating https://github.com/nicklockwood/SwiftFormat.git
Updating https://github.com/swiftlang/swift-syntax.git
Updating https://github.com/apple/swift-collections.git
Updating https://github.com/apple/swift-async-algorithms.git
Fetched https://github.com/swiftlang/swift-docc-plugin from cache (1.24s)
Updated https://github.com/apple/swift-collections.git (1.51s)
Updated https://github.com/nicklockwood/SwiftFormat.git (1.51s)
Updated https://github.com/swiftlang/swift-syntax.git (1.51s)
Updated https://github.com/apple/swift-async-algorithms.git (1.51s)
Computing version for https://github.com/swiftlang/swift-syntax.git
Computed https://github.com/swiftlang/swift-syntax.git at 602.0.0 (3.43s)
Computing version for https://github.com/nicklockwood/SwiftFormat.git
Computed https://github.com/nicklockwood/SwiftFormat.git at 0.58.7 (0.54s)
Computing version for https://github.com/apple/swift-async-algorithms.git
Computed https://github.com/apple/swift-async-algorithms.git at 1.1.0 (0.50s)
Computing version for https://github.com/apple/swift-collections.git
Computed https://github.com/apple/swift-collections.git at 1.3.0 (0.54s)
Computing version for https://github.com/swiftlang/swift-docc-plugin
Computed https://github.com/swiftlang/swift-docc-plugin at 1.4.5 (0.61s)
Fetching https://github.com/swiftlang/swift-docc-symbolkit
[1/3583] Fetching swift-docc-symbolkit
Fetched https://github.com/swiftlang/swift-docc-symbolkit from cache (1.29s)
Computing version for https://github.com/swiftlang/swift-docc-symbolkit
Computed https://github.com/swiftlang/swift-docc-symbolkit at 1.0.0 (1.97s)
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.5
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
Building for debugging...
[0/8] Write sources
[0/8] Write snippet-extract-tool-entitlement.plist
[0/8] Write sources
[4/8] Write swift-version-49B95AFC49DCD68C.txt
[6/53] Compiling SymbolKit DeclarationFragments.swift
[7/53] Compiling SymbolKit Fragment.swift
[8/53] Compiling SymbolKit FragmentKind.swift
[9/53] Compiling SymbolKit FunctionParameter.swift
[10/53] Compiling SymbolKit FunctionSignature.swift
[11/57] Emitting module SymbolKit
[12/57] Compiling SymbolKit Names.swift
[13/57] Compiling SymbolKit SPI.swift
[14/57] Compiling SymbolKit Snippet.swift
[15/57] Compiling SymbolKit Extension.swift
[16/57] Compiling SymbolKit SourceRange.swift
[17/57] Compiling SymbolKit Metadata.swift
[18/57] Compiling SymbolKit Module.swift
[19/57] Compiling SymbolKit OperatingSystem.swift
[20/57] Compiling SymbolKit Platform.swift
[21/57] Compiling Snippets SnippetParser.swift
[22/57] Compiling Snippets Snippet.swift
[23/57] Emitting module Snippets
[24/57] Compiling SymbolKit Symbol.swift
[25/57] Compiling SymbolKit SymbolKind.swift
[26/57] Compiling SymbolKit SymbolGraph.swift
[27/57] Compiling SymbolKit GraphCollector.swift
[28/57] Compiling SymbolKit SemanticVersion.swift
[29/57] Compiling SymbolKit AccessControl.swift
[30/57] Compiling SymbolKit Availability.swift
[31/57] Compiling SymbolKit AvailabilityItem.swift
[32/57] Compiling SymbolKit Domain.swift
[33/57] Compiling SymbolKit Relationship.swift
[34/57] Compiling SymbolKit RelationshipKind.swift
[35/57] Compiling SymbolKit SourceOrigin.swift
[36/57] Compiling SymbolKit GenericConstraints.swift
[37/57] Compiling SymbolKit Swift.swift
[38/57] Compiling SymbolKit GenericConstraint.swift
[39/57] Compiling SymbolKit GenericParameter.swift
[40/57] Compiling SymbolKit Generics.swift
[41/57] Compiling SymbolKit Namespace.swift
[42/57] Compiling SymbolKit Identifier.swift
[43/57] Compiling SymbolKit KindIdentifier.swift
[44/57] Compiling SymbolKit Location.swift
[45/57] Compiling SymbolKit Mutability.swift
[46/57] Compiling SymbolKit Mixin+Equals.swift
[47/57] Compiling SymbolKit Mixin+Hash.swift
[48/57] Compiling SymbolKit Mixin.swift
[49/57] Compiling SymbolKit LineList.swift
[50/57] Compiling SymbolKit Position.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! (3.94s)
Building for debugging...
[0/1] Write swift-version-49B95AFC49DCD68C.txt
Build of target: 'Vexil' complete! (0.96s)
Target:                   Vexillographer
Extracting symbol information for 'Vexillographer'...
Finished extracting symbol information for 'Vexillographer'. (1.58s)
Building documentation for 'Vexillographer'...
Finished building documentation for 'Vexillographer' (2.48s)
Generated documentation archive at:
  /Users/admin/builder/spi-builder-workspace/.docs/unsignedapps/vexil/main
Building for debugging...
[0/3] Write swift-version-49B95AFC49DCD68C.txt
Build of product 'snippet-extract' complete! (0.59s)
Building for debugging...
[0/1] Write swift-version-49B95AFC49DCD68C.txt
Build of target: 'Vexillographer' complete! (1.04s)
Successfully merged into /Users/admin/builder/spi-builder-workspace/.docs-staging/unsignedapps/vexil/main/index/index.json
Successfully merged into /Users/admin/builder/spi-builder-workspace/.docs-staging/unsignedapps/vexil/main/linkable-paths.json
   10202
65	/Users/admin/builder/spi-builder-workspace/.docs/unsignedapps/vexil/main
✅  Doc result (uploading) reported
========================================
SyncDocs
========================================
Doc archive source directory: $PWD/.docs/unsignedapps/vexil/main
File count: 10202
Doc size:   65.0MB
Preparing doc bundle ...
Uploading prod-unsignedapps-vexil-main-d7075b7a.zip to s3://spi-docs-inbox/prod-unsignedapps-vexil-main-d7075b7a.zip
Copying... [10%]
Copying... [20%]
Copying... [30%]
Copying... [40%]
Copying... [50%]
Copying... [60%]
Copying... [70%]
Copying... [80%]
Copying... [90%]
Copying... [100%]
Done.