The Swift Package Index logo.Swift Package Index

Track the adoption of Swift 6 strict concurrency checks for data race safety. How many packages are Ready for Swift 6?

Build Information

Successful build of ApplicationExtensions, reference master (f858e0), with Swift 6.0 for macOS (SPM) on 28 Nov 2024 00:30:08 UTC.

Swift 6 data race errors: 0

Build Command

env DEVELOPER_DIR=/Applications/Xcode-16.1.0.app xcrun swift build --arch arm64 -Xswiftc -Xfrontend -Xswiftc -stats-output-dir -Xswiftc -Xfrontend -Xswiftc .stats -Xswiftc -strict-concurrency=complete -Xswiftc -enable-upcoming-feature -Xswiftc StrictConcurrency -Xswiftc -enable-upcoming-feature -Xswiftc DisableOutwardActorInference -Xswiftc -enable-upcoming-feature -Xswiftc GlobalActorIsolatedTypesUsability -Xswiftc -enable-upcoming-feature -Xswiftc InferSendableFromCaptures

Build Log

========================================
RunAll
========================================
Builder version: 4.58.0
Interrupt handler set up.
========================================
Checkout
========================================
Clone URL: https://github.com/elegantchaos/ApplicationExtensions.git
Reference: master
Initialized empty Git repository in /Users/admin/builder/spi-builder-workspace/.git/
From https://github.com/elegantchaos/ApplicationExtensions
 * branch            master     -> FETCH_HEAD
 * [new branch]      master     -> origin/master
HEAD is now at f858e00 Improved parallelism in state saving
Cloned https://github.com/elegantchaos/ApplicationExtensions.git
Revision (git rev-parse @):
f858e00faa4a80c88d7fe3d154cd57f7dc6609de
SUCCESS checkout https://github.com/elegantchaos/ApplicationExtensions.git at master
Fetching https://github.com/elegantchaos/Logger.git
Fetching https://github.com/elegantchaos/XCTestExtensions
Fetching https://github.com/elegantchaos/SemanticVersion.git
Fetching https://github.com/elegantchaos/Files.git
Fetching https://github.com/elegantchaos/CollectionExtensions.git
Fetching https://github.com/elegantchaos/Images.git
Fetching https://github.com/elegantchaos/Bundles.git
[1/687] Fetching files
[8/1258] Fetching files, xctestextensions
[14/1410] Fetching files, xctestextensions, semanticversion
[123/1810] Fetching files, xctestextensions, semanticversion, collectionextensions
[412/3861] Fetching files, xctestextensions, semanticversion, collectionextensions, logger
[433/4080] Fetching files, xctestextensions, semanticversion, collectionextensions, logger, bundles
[698/4242] Fetching files, xctestextensions, semanticversion, collectionextensions, logger, bundles, images
Fetched https://github.com/elegantchaos/Images.git from cache (0.89s)
Fetched https://github.com/elegantchaos/CollectionExtensions.git from cache (0.89s)
Fetching https://github.com/elegantchaos/Coercion.git
[2448/3680] Fetching files, xctestextensions, semanticversion, logger, bundles
Fetched https://github.com/elegantchaos/Files.git from cache (1.00s)
Fetched https://github.com/elegantchaos/SemanticVersion.git from cache (1.00s)
Fetched https://github.com/elegantchaos/Bundles.git from cache (1.00s)
Fetched https://github.com/elegantchaos/Logger.git from cache (1.00s)
Fetched https://github.com/elegantchaos/XCTestExtensions from cache (1.00s)
Computing version for https://github.com/elegantchaos/Logger.git
[1/274] Fetching coercion
Computed https://github.com/elegantchaos/Logger.git at 1.5.7 (0.55s)
Computing version for https://github.com/elegantchaos/CollectionExtensions.git
Fetched https://github.com/elegantchaos/Coercion.git from cache (0.72s)
Computed https://github.com/elegantchaos/CollectionExtensions.git at 1.0.2 (0.54s)
Computing version for https://github.com/elegantchaos/Bundles.git
Computed https://github.com/elegantchaos/Bundles.git at 1.0.6 (0.54s)
Computing version for https://github.com/elegantchaos/SemanticVersion.git
Computed https://github.com/elegantchaos/SemanticVersion.git at 1.1.0 (0.53s)
Computing version for https://github.com/elegantchaos/Files.git
Computed https://github.com/elegantchaos/Files.git at 1.1.3 (0.54s)
Computing version for https://github.com/elegantchaos/Images.git
Computed https://github.com/elegantchaos/Images.git at 1.0.0 (0.54s)
Computing version for https://github.com/elegantchaos/Coercion.git
Computed https://github.com/elegantchaos/Coercion.git at 1.0.3 (0.54s)
Computing version for https://github.com/elegantchaos/XCTestExtensions
Computed https://github.com/elegantchaos/XCTestExtensions at 1.1.2 (0.54s)
Creating working copy for https://github.com/elegantchaos/Logger.git
Working copy of https://github.com/elegantchaos/Logger.git resolved at 1.5.7
Creating working copy for https://github.com/elegantchaos/Images.git
Working copy of https://github.com/elegantchaos/Images.git resolved at 1.0.0
Creating working copy for https://github.com/elegantchaos/Bundles.git
Working copy of https://github.com/elegantchaos/Bundles.git resolved at 1.0.6
Creating working copy for https://github.com/elegantchaos/Files.git
Working copy of https://github.com/elegantchaos/Files.git resolved at 1.1.3
Creating working copy for https://github.com/elegantchaos/Coercion.git
Working copy of https://github.com/elegantchaos/Coercion.git resolved at 1.0.3
Creating working copy for https://github.com/elegantchaos/XCTestExtensions
Working copy of https://github.com/elegantchaos/XCTestExtensions resolved at 1.1.2
Creating working copy for https://github.com/elegantchaos/SemanticVersion.git
Working copy of https://github.com/elegantchaos/SemanticVersion.git resolved at 1.1.0
Creating working copy for https://github.com/elegantchaos/CollectionExtensions.git
Working copy of https://github.com/elegantchaos/CollectionExtensions.git resolved at 1.0.2
========================================
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": "applicationextensions",
      "name": "ApplicationExtensions",
      "url": "https://github.com/elegantchaos/ApplicationExtensions.git",
      "version": "unspecified",
      "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/ApplicationExtensions",
      "dependencies": [
        {
          "identity": "bundles",
          "name": "Bundles",
          "url": "https://github.com/elegantchaos/Bundles.git",
          "version": "1.0.10",
          "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/Bundles",
          "dependencies": [
            {
              "identity": "coercion",
              "name": "Coercion",
              "url": "https://github.com/elegantchaos/Coercion.git",
              "version": "1.1.3",
              "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/Coercion",
              "dependencies": [
              ]
            },
            {
              "identity": "images",
              "name": "Images",
              "url": "https://github.com/elegantchaos/Images.git",
              "version": "1.1.6",
              "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/Images",
              "dependencies": [
                {
                  "identity": "logger",
                  "name": "Logger",
                  "url": "https://github.com/elegantchaos/Logger.git",
                  "version": "1.8.2",
                  "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/Logger",
                  "dependencies": [
                  ]
                },
                {
                  "identity": "threadextensions",
                  "name": "ThreadExtensions",
                  "url": "https://github.com/elegantchaos/ThreadExtensions.git",
                  "version": "1.0.1",
                  "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/ThreadExtensions",
                  "dependencies": [
                  ]
                }
              ]
            },
            {
              "identity": "files",
              "name": "Files",
              "url": "https://github.com/elegantchaos/Files.git",
              "version": "1.2.2",
              "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/Files",
              "dependencies": [
                {
                  "identity": "xctestextensions",
                  "name": "XCTestExtensions",
                  "url": "https://github.com/elegantchaos/XCTestExtensions.git",
                  "version": "1.5.1",
                  "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/XCTestExtensions",
                  "dependencies": [
                    {
                      "identity": "matchable",
                      "name": "Matchable",
                      "url": "https://github.com/elegantchaos/Matchable.git",
                      "version": "1.0.7",
                      "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/Matchable",
                      "dependencies": [
                      ]
                    }
                  ]
                }
              ]
            },
            {
              "identity": "semanticversion",
              "name": "SemanticVersion",
              "url": "https://github.com/elegantchaos/SemanticVersion.git",
              "version": "1.1.2",
              "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/SemanticVersion",
              "dependencies": [
              ]
            }
          ]
        },
        {
          "identity": "collectionextensions",
          "name": "CollectionExtensions",
          "url": "https://github.com/elegantchaos/CollectionExtensions.git",
          "version": "1.1.10",
          "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/CollectionExtensions",
          "dependencies": [
          ]
        },
        {
          "identity": "logger",
          "name": "Logger",
          "url": "https://github.com/elegantchaos/Logger.git",
          "version": "1.8.2",
          "path": "/Users/admin/builder/spi-builder-workspace/.resolve-product-dependencies/.build/checkouts/Logger",
          "dependencies": [
          ]
        }
      ]
    }
  ]
}
Fetching https://github.com/elegantchaos/ApplicationExtensions.git
[1/424] Fetching applicationextensions
Fetched https://github.com/elegantchaos/ApplicationExtensions.git from cache (0.78s)
Fetching https://github.com/elegantchaos/CollectionExtensions.git from cache
Fetching https://github.com/elegantchaos/Bundles.git from cache
Fetching https://github.com/elegantchaos/Logger.git from cache
Fetched https://github.com/elegantchaos/Bundles.git from cache (0.47s)
Fetched https://github.com/elegantchaos/Logger.git from cache (0.48s)
Fetched https://github.com/elegantchaos/CollectionExtensions.git from cache (0.48s)
Computing version for https://github.com/elegantchaos/Bundles.git
Computed https://github.com/elegantchaos/Bundles.git at 1.0.10 (0.53s)
Fetching https://github.com/elegantchaos/Images.git from cache
Fetching https://github.com/elegantchaos/SemanticVersion.git from cache
Fetching https://github.com/elegantchaos/Files.git from cache
Fetching https://github.com/elegantchaos/Coercion.git from cache
Fetched https://github.com/elegantchaos/Images.git from cache (0.49s)
Fetched https://github.com/elegantchaos/SemanticVersion.git from cache (0.49s)
Fetched https://github.com/elegantchaos/Coercion.git from cache (0.49s)
Fetched https://github.com/elegantchaos/Files.git from cache (0.49s)
Computing version for https://github.com/elegantchaos/Files.git
Computed https://github.com/elegantchaos/Files.git at 1.2.2 (0.52s)
Fetching https://github.com/elegantchaos/XCTestExtensions.git from cache
Fetched https://github.com/elegantchaos/XCTestExtensions.git from cache (0.49s)
Computing version for https://github.com/elegantchaos/Images.git
Computed https://github.com/elegantchaos/Images.git at 1.1.6 (0.51s)
Fetching https://github.com/elegantchaos/ThreadExtensions.git
[1/42] Fetching threadextensions
Fetched https://github.com/elegantchaos/ThreadExtensions.git from cache (0.63s)
Computing version for https://github.com/elegantchaos/ThreadExtensions.git
Computed https://github.com/elegantchaos/ThreadExtensions.git at 1.0.1 (0.51s)
Computing version for https://github.com/elegantchaos/SemanticVersion.git
Computed https://github.com/elegantchaos/SemanticVersion.git at 1.1.2 (0.02s)
Computing version for https://github.com/elegantchaos/Coercion.git
Computed https://github.com/elegantchaos/Coercion.git at 1.1.3 (0.02s)
Computing version for https://github.com/elegantchaos/Logger.git
Computed https://github.com/elegantchaos/Logger.git at 1.8.2 (0.55s)
Computing version for https://github.com/elegantchaos/XCTestExtensions.git
Computed https://github.com/elegantchaos/XCTestExtensions.git at 1.5.1 (0.49s)
Fetching https://github.com/elegantchaos/Matchable.git
[1/113] Fetching matchable
Fetched https://github.com/elegantchaos/Matchable.git from cache (0.71s)
Computing version for https://github.com/elegantchaos/Matchable.git
Computed https://github.com/elegantchaos/Matchable.git at 1.0.7 (0.50s)
Computing version for https://github.com/elegantchaos/CollectionExtensions.git
Computed https://github.com/elegantchaos/CollectionExtensions.git at 1.1.10 (0.51s)
Creating working copy for https://github.com/elegantchaos/ThreadExtensions.git
Working copy of https://github.com/elegantchaos/ThreadExtensions.git resolved at 1.0.1
Creating working copy for https://github.com/elegantchaos/XCTestExtensions.git
Working copy of https://github.com/elegantchaos/XCTestExtensions.git resolved at 1.5.1
Creating working copy for https://github.com/elegantchaos/CollectionExtensions.git
Working copy of https://github.com/elegantchaos/CollectionExtensions.git resolved at 1.1.10
Creating working copy for https://github.com/elegantchaos/SemanticVersion.git
Working copy of https://github.com/elegantchaos/SemanticVersion.git resolved at 1.1.2
Creating working copy for https://github.com/elegantchaos/Images.git
Working copy of https://github.com/elegantchaos/Images.git resolved at 1.1.6
Creating working copy for https://github.com/elegantchaos/ApplicationExtensions.git
Working copy of https://github.com/elegantchaos/ApplicationExtensions.git resolved at master (f858e00)
Creating working copy for https://github.com/elegantchaos/Logger.git
Working copy of https://github.com/elegantchaos/Logger.git resolved at 1.8.2
Creating working copy for https://github.com/elegantchaos/Matchable.git
Working copy of https://github.com/elegantchaos/Matchable.git resolved at 1.0.7
Creating working copy for https://github.com/elegantchaos/Files.git
Working copy of https://github.com/elegantchaos/Files.git resolved at 1.2.2
Creating working copy for https://github.com/elegantchaos/Bundles.git
Working copy of https://github.com/elegantchaos/Bundles.git resolved at 1.0.10
Creating working copy for https://github.com/elegantchaos/Coercion.git
Working copy of https://github.com/elegantchaos/Coercion.git resolved at 1.1.3
warning: '.resolve-product-dependencies': dependency 'applicationextensions' is not used by any target
Found 3 product dependencies
  - Bundles
  - CollectionExtensions
  - Logger
========================================
Build
========================================
Selected platform:         macosSpm
Swift version:             6.0
Building package at path:  $PWD
https://github.com/elegantchaos/ApplicationExtensions.git
Running build ...
env DEVELOPER_DIR=/Applications/Xcode-16.1.0.app xcrun swift build --arch arm64 -Xswiftc -Xfrontend -Xswiftc -stats-output-dir -Xswiftc -Xfrontend -Xswiftc .stats -Xswiftc -strict-concurrency=complete -Xswiftc -enable-upcoming-feature -Xswiftc StrictConcurrency -Xswiftc -enable-upcoming-feature -Xswiftc DisableOutwardActorInference -Xswiftc -enable-upcoming-feature -Xswiftc GlobalActorIsolatedTypesUsability -Xswiftc -enable-upcoming-feature -Xswiftc InferSendableFromCaptures
Building for debugging...
[0/10] Write sources
[9/10] Write swift-version--7754E27361AE5C74.txt
[11/58] Compiling SemanticVersion SemanticVersion.swift
[12/58] Emitting module SemanticVersion
[13/58] Compiling Coercion UIntConvertible.swift
[14/58] Compiling Coercion StringConvertible.swift
[15/59] Compiling Coercion StandardConvertible.swift
[16/59] Compiling Coercion IntConvertible.swift
[17/59] Compiling Logger PrintHandler.swift
[18/59] Compiling Logger OSLogHandler.swift
[19/59] Emitting module Images
[20/59] Compiling Files URL+General.swift
[21/60] Compiling Coercion String+Coercion.swift
[22/60] Compiling CollectionExtensions Dictionary+Coercion.swift
[23/60] Compiling Files ThrowingManager.swift
[24/60] Compiling CollectionExtensions Dictionary+Merging.swift
[25/60] Compiling Files ThrowingFolder.swift
[26/60] Compiling Files ThrowingItem.swift
[27/60] Compiling Coercion DateConvertible.swift
[28/60] Compiling Coercion DoubleConvertible.swift
[29/60] Compiling Coercion BoolConvertible.swift
[30/60] Compiling Coercion DataConvertible.swift
[31/60] Compiling Coercion Dictionary+Coercion.swift
[32/60] Compiling Coercion Double+Coercion.swift
[35/60] Compiling Files NonThrowingManager.swift
[36/60] Compiling Files ThrowingFile.swift
[37/60] Emitting module CollectionExtensions
[38/60] Compiling CollectionExtensions Coercion.swift
[43/60] Emitting module Coercion
[44/60] Compiling Coercion BinaryInteger+Coercion.swift
[45/60] Compiling Coercion Bool+Coercion.swift
[46/60] Compiling Files FolderManager.swift
[47/60] Compiling Files Item.swift
[48/60] Emitting module Files
[53/60] Compiling Logger Handler.swift
[54/60] Compiling Logger NSLogHandler.swift
[55/60] Compiling Logger Context.swift
[56/60] Emitting module Logger
[57/60] Compiling Logger Manager.swift
[58/60] Compiling Logger Channel.swift
[59/60] Compiling Files URL+Security.swift
[60/70] Compiling Images Images.swift
[61/73] Compiling Bundles BundleInfo.swift
[62/73] Emitting module Bundles
[63/73] Compiling Bundles Bundle+Decoding.swift
[64/73] Compiling LoggerKit LoggerMenu+UIKit.swift
[65/73] Compiling LoggerKit LoggerMenu+AppKit.swift
[66/73] Compiling LoggerKit LoggerApplication+UIKit.swift
[67/73] Compiling LoggerKit LoggerApplication+LoggerMenu.swift
[68/73] Compiling LoggerKit ChainableResponder.swift
[69/73] Compiling LoggerKit LoggerApplication+AppKit.swift
[70/73] Emitting module LoggerKit
[71/73] Compiling LoggerKit LoggerApplication.swift
[72/73] Compiling LoggerKit LoggerScene.swift
[73/73] Compiling LoggerKit LoggerSettingsView.swift
[74/80] Compiling ApplicationExtensions DocumentExtensions.swift
[75/80] Compiling ApplicationExtensions StateWatcher.swift
[76/80] Compiling ApplicationExtensions DispatchQueue+Extensions.swift
/Users/admin/builder/spi-builder-workspace/Sources/ApplicationExtensions/DispatchQueue+Extensions.swift:9:39: warning: passing non-sendable parameter 'work' to function expecting a @Sendable closure
 6 | import Foundation
 7 |
 8 | public func onMainQueue(_ work: @escaping () -> ()) {
   |                           `- note: parameter 'work' is implicitly non-sendable
 9 |     DispatchQueue.main.async(execute: work)
   |                                       `- warning: passing non-sendable parameter 'work' to function expecting a @Sendable closure
10 | }
11 |
/Users/admin/builder/spi-builder-workspace/Sources/ApplicationExtensions/DispatchQueue+Extensions.swift:13:72: warning: passing non-sendable parameter 'work' to function expecting a @Sendable closure
10 | }
11 |
12 | public func onMainQueue(after seconds: TimeInterval, _ work: @escaping () -> ()) {
   |                                                        `- note: parameter 'work' is implicitly non-sendable
13 |     DispatchQueue.main.asyncAfter(deadline: .now() + seconds, execute: work)
   |                                                                        `- warning: passing non-sendable parameter 'work' to function expecting a @Sendable closure
14 | }
15 |
[77/80] Compiling ApplicationExtensions BasicScene.swift
[78/80] Compiling ApplicationExtensions ApplicationExtensions.swift
[79/80] Emitting module ApplicationExtensions
[80/80] Compiling ApplicationExtensions BasicApplication.swift
/Users/admin/builder/spi-builder-workspace/Sources/ApplicationExtensions/BasicApplication.swift:70:45: warning: capture of 'options' with non-sendable type 'BasicApplication.LaunchOptions' (aka 'Dictionary<String, Any>') in a `@Sendable` closure; this is an error in the Swift 6 language mode
 68 |                 self.setupState = .initialising
 69 |                 DispatchQueue.global(qos: .userInitiated).async {
 70 |                     self.setUp(withOptions: options) { _ in
    |                                             `- warning: capture of 'options' with non-sendable type 'BasicApplication.LaunchOptions' (aka 'Dictionary<String, Any>') in a `@Sendable` closure; this is an error in the Swift 6 language mode
 71 |                         self.finishedSetup()
 72 |                     }
/Users/admin/builder/spi-builder-workspace/Sources/ApplicationExtensions/BasicApplication.swift:70:26: warning: call to main actor-isolated instance method 'setUp(withOptions:completion:)' in a synchronous nonisolated context; this is an error in the Swift 6 language mode
 34 |     }
 35 |
 36 |     open func setUp(withOptions options: LaunchOptions, completion: @escaping SetupCompletion) {
    |               `- note: calls to instance method 'setUp(withOptions:completion:)' from outside of its actor context are implicitly asynchronous
 37 |         registerDefaultsFromSettingsBundle()
 38 |         loadState {
    :
 68 |                 self.setupState = .initialising
 69 |                 DispatchQueue.global(qos: .userInitiated).async {
 70 |                     self.setUp(withOptions: options) { _ in
    |                          `- warning: call to main actor-isolated instance method 'setUp(withOptions:completion:)' in a synchronous nonisolated context; this is an error in the Swift 6 language mode
 71 |                         self.finishedSetup()
 72 |                     }
/Users/admin/builder/spi-builder-workspace/Sources/ApplicationExtensions/BasicApplication.swift:71:30: warning: call to main actor-isolated instance method 'finishedSetup()' in a synchronous nonisolated context; this is an error in the Swift 6 language mode
 69 |                 DispatchQueue.global(qos: .userInitiated).async {
 70 |                     self.setUp(withOptions: options) { _ in
 71 |                         self.finishedSetup()
    |                              `- warning: call to main actor-isolated instance method 'finishedSetup()' in a synchronous nonisolated context; this is an error in the Swift 6 language mode
 72 |                     }
 73 |                 }
    :
 76 |     }
 77 |
 78 |     fileprivate func finishedSetup() {
    |                      `- note: calls to instance method 'finishedSetup()' from outside of its actor context are implicitly asynchronous
 79 |         onMainQueue {
 80 |             applicationChannel.log("finished setup")
Build complete! (21.95s)
Build complete.
{
  "dependencies" : [
    {
      "identity" : "bundles",
      "requirement" : {
        "range" : [
          {
            "lower_bound" : "1.0.6",
            "upper_bound" : "2.0.0"
          }
        ]
      },
      "type" : "sourceControl",
      "url" : "https://github.com/elegantchaos/Bundles.git"
    },
    {
      "identity" : "collectionextensions",
      "requirement" : {
        "range" : [
          {
            "lower_bound" : "1.0.2",
            "upper_bound" : "2.0.0"
          }
        ]
      },
      "type" : "sourceControl",
      "url" : "https://github.com/elegantchaos/CollectionExtensions.git"
    },
    {
      "identity" : "logger",
      "requirement" : {
        "range" : [
          {
            "lower_bound" : "1.5.7",
            "upper_bound" : "2.0.0"
          }
        ]
      },
      "type" : "sourceControl",
      "url" : "https://github.com/elegantchaos/Logger.git"
    }
  ],
  "manifest_display_name" : "ApplicationExtensions",
  "name" : "ApplicationExtensions",
  "path" : "/Users/admin/builder/spi-builder-workspace",
  "platforms" : [
    {
      "name" : "macos",
      "version" : "10.13"
    },
    {
      "name" : "ios",
      "version" : "13.0"
    },
    {
      "name" : "tvos",
      "version" : "13.0"
    }
  ],
  "products" : [
    {
      "name" : "ApplicationExtensions",
      "targets" : [
        "ApplicationExtensions"
      ],
      "type" : {
        "library" : [
          "automatic"
        ]
      }
    }
  ],
  "targets" : [
    {
      "c99name" : "ApplicationExtensionsTests",
      "module_type" : "SwiftTarget",
      "name" : "ApplicationExtensionsTests",
      "path" : "Tests/ApplicationExtensionsTests",
      "sources" : [
        "ApplicationExtensionsTests.swift",
        "XCTestManifests.swift"
      ],
      "target_dependencies" : [
        "ApplicationExtensions"
      ],
      "type" : "test"
    },
    {
      "c99name" : "ApplicationExtensions",
      "module_type" : "SwiftTarget",
      "name" : "ApplicationExtensions",
      "path" : "Sources/ApplicationExtensions",
      "product_dependencies" : [
        "Bundles",
        "LoggerKit",
        "CollectionExtensions"
      ],
      "product_memberships" : [
        "ApplicationExtensions"
      ],
      "sources" : [
        "ApplicationExtensions.swift",
        "BasicApplication.swift",
        "BasicScene.swift",
        "DispatchQueue+Extensions.swift",
        "DocumentExtensions.swift",
        "StateWatcher.swift"
      ],
      "type" : "library"
    }
  ],
  "tools_version" : "5.1"
}
Done.