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

Failed to build Appcast, reference main (21968e), with Swift 6.0 for Linux on 14 Apr 2025 16:50:06 UTC.

Build Command

bash -c docker run --pull=always --rm -v "checkouts-4606859-0":/host -w "$PWD" registry.gitlab.com/finestructure/spi-images:basic-6.0-latest swift build --triple x86_64-unknown-linux-gnu 2>&1

Build Log

========================================
RunAll
========================================
Builder version: 4.60.1
Interrupt handler set up.
========================================
Checkout
========================================
Clone URL: https://github.com/slidoapp/Appcast.git
Reference: main
Initialized empty Git repository in /host/spi-builder-workspace/.git/
hint: Using 'master' as the name for the initial branch. This default branch name
hint: is subject to change. To configure the initial branch name to use in all
hint: of your new repositories, which will suppress this warning, call:
hint:
hint: 	git config --global init.defaultBranch <name>
hint:
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
hint: 'development'. The just-created branch can be renamed via this command:
hint:
hint: 	git branch -m <name>
From https://github.com/slidoapp/Appcast
 * branch            main       -> FETCH_HEAD
 * [new branch]      main       -> origin/main
HEAD is now at 21968ef Appcast package v0.4.0
Cloned https://github.com/slidoapp/Appcast.git
Revision (git rev-parse @):
21968efcdf1aff6f65a901ef0c3dec1b2f5e3a7f
SUCCESS checkout https://github.com/slidoapp/Appcast.git at main
========================================
Build
========================================
Selected platform:         linux
Swift version:             6.0
Building package at path:  $PWD
https://github.com/slidoapp/Appcast.git
https://github.com/slidoapp/Appcast.git
WARNING: environment variable SUPPRESS_SWIFT_6_FLAGS is not set
{
  "dependencies" : [
  ],
  "manifest_display_name" : "Appcast",
  "name" : "Appcast",
  "path" : "/host/spi-builder-workspace",
  "platforms" : [
  ],
  "products" : [
    {
      "name" : "Appcast",
      "targets" : [
        "Appcast"
      ],
      "type" : {
        "library" : [
          "automatic"
        ]
      }
    }
  ],
  "targets" : [
    {
      "c99name" : "IntegrationTests",
      "module_type" : "SwiftTarget",
      "name" : "IntegrationTests",
      "path" : "Tests/IntegrationTests",
      "resources" : [
        {
          "path" : "/host/spi-builder-workspace/Tests/IntegrationTests/Resources/test-dangerous-link.xml",
          "rule" : {
            "process" : {
            }
          }
        },
        {
          "path" : "/host/spi-builder-workspace/Tests/IntegrationTests/Resources/test-links.xml",
          "rule" : {
            "process" : {
            }
          }
        },
        {
          "path" : "/host/spi-builder-workspace/Tests/IntegrationTests/Resources/test-relative-urls.xml",
          "rule" : {
            "process" : {
            }
          }
        },
        {
          "path" : "/host/spi-builder-workspace/Tests/IntegrationTests/Resources/testappcast.xml",
          "rule" : {
            "process" : {
            }
          }
        },
        {
          "path" : "/host/spi-builder-workspace/Tests/IntegrationTests/Resources/testappcast_channels.xml",
          "rule" : {
            "process" : {
            }
          }
        },
        {
          "path" : "/host/spi-builder-workspace/Tests/IntegrationTests/Resources/testappcast_delta.xml",
          "rule" : {
            "process" : {
            }
          }
        },
        {
          "path" : "/host/spi-builder-workspace/Tests/IntegrationTests/Resources/testappcast_info_updates.xml",
          "rule" : {
            "process" : {
            }
          }
        },
        {
          "path" : "/host/spi-builder-workspace/Tests/IntegrationTests/Resources/testappcast_minimumAutoupdateVersion.xml",
          "rule" : {
            "process" : {
            }
          }
        },
        {
          "path" : "/host/spi-builder-workspace/Tests/IntegrationTests/Resources/testappcast_minimumAutoupdateVersionSkipping.xml",
          "rule" : {
            "process" : {
            }
          }
        },
        {
          "path" : "/host/spi-builder-workspace/Tests/IntegrationTests/Resources/testappcast_minimumAutoupdateVersionSkipping2.xml",
          "rule" : {
            "process" : {
            }
          }
        },
        {
          "path" : "/host/spi-builder-workspace/Tests/IntegrationTests/Resources/testappcast_phasedRollout.xml",
          "rule" : {
            "process" : {
            }
          }
        },
        {
          "path" : "/host/spi-builder-workspace/Tests/IntegrationTests/Resources/testlocalizedreleasenotesappcast.xml",
          "rule" : {
            "process" : {
            }
          }
        },
        {
          "path" : "/host/spi-builder-workspace/Tests/IntegrationTests/Resources/testnamespaces.xml",
          "rule" : {
            "process" : {
            }
          }
        }
      ],
      "sources" : [
        "SUAppcastChannelTests.swift",
        "SUAppcastCriticalUpdateTests.swift",
        "SUAppcastDangerousLinkTests.swift",
        "SUAppcastDriverTests.swift",
        "SUAppcastInformationalUpdateTests.swift",
        "SUAppcastLinkTests.swift",
        "SUAppcastMinimumAutoupdateTests.swift",
        "SUAppcastParserNamespacesTests.swift",
        "SUAppcastParserTests.swift",
        "SUAppcastPhasedGroupRolloutsTests.swift",
        "SUAppcastReleaseNotesTests.swift",
        "SUAppcastTest.swift"
      ],
      "target_dependencies" : [
        "Appcast"
      ],
      "type" : "test"
    },
    {
      "c99name" : "AppcastTests",
      "module_type" : "SwiftTarget",
      "name" : "AppcastTests",
      "path" : "Tests/AppcastTests",
      "resources" : [
        {
          "path" : "/host/spi-builder-workspace/Tests/AppcastTests/Resources/appcast_simple.xml",
          "rule" : {
            "process" : {
            }
          }
        }
      ],
      "sources" : [
        "AlwaysPassTests.swift",
        "SPUAppcastItemStateTests.swift",
        "SPUDownloadDataTests.swift",
        "SUAppcastItemBaseTests.swift",
        "SUAppcastItemTests+displayVersionString.swift",
        "SUAppcastItemTests+isCriticalUpdate.swift",
        "SUAppcastItemTests+isInformationOnlyUpdate.swift",
        "SUAppcastItemTests+isMajorUpgrade.swift",
        "SUAppcastTests.swift",
        "SUOperatingSystemTests.swift",
        "SUStandardVersionComparatorTests.swift"
      ],
      "target_dependencies" : [
        "Appcast"
      ],
      "type" : "test"
    },
    {
      "c99name" : "Appcast",
      "module_type" : "SwiftTarget",
      "name" : "Appcast",
      "path" : "Sources/Appcast",
      "product_memberships" : [
        "Appcast"
      ],
      "sources" : [
        "Appcast.swift",
        "Constants.swift",
        "SPUAppcastItemState.swift",
        "SPUAppcastItemStateResolver.swift",
        "SPUDownloadData.swift",
        "SPUSkippedUpdate.swift",
        "SUAppcast.swift",
        "SUAppcastDriver.swift",
        "SUAppcastItem.swift",
        "SUOperatingSystem.swift",
        "SUSignatures.swift",
        "SUStandardVersionComparator.swift",
        "SUVersionComparison.swift"
      ],
      "type" : "library"
    }
  ],
  "tools_version" : "5.8"
}
Running build ...
bash -c docker run --pull=always --rm -v "checkouts-4606859-0":/host -w "$PWD" registry.gitlab.com/finestructure/spi-images:basic-6.0-latest swift build --triple x86_64-unknown-linux-gnu -Xswiftc -Xfrontend -Xswiftc -stats-output-dir -Xswiftc -Xfrontend -Xswiftc .stats -Xswiftc -strict-concurrency=complete -Xswiftc -enable-upcoming-feature -Xswiftc StrictConcurrency -Xswiftc -enable-upcoming-feature -Xswiftc DisableOutwardActorInference -Xswiftc -enable-upcoming-feature -Xswiftc GlobalActorIsolatedTypesUsability -Xswiftc -enable-upcoming-feature -Xswiftc InferSendableFromCaptures 2>&1
basic-6.0-latest: Pulling from finestructure/spi-images
Digest: sha256:9029076bb687edc160a3d5201c89e92dd9fa7309f33f090c4234365c83366c31
Status: Image is up to date for registry.gitlab.com/finestructure/spi-images:basic-6.0-latest
Building for debugging...
[0/2] Write sources
[1/2] Write swift-version-24593BA9C3E375BF.txt
error: emit-module command failed with exit code 1 (use -v to see invocation)
[3/15] Emitting module Appcast
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:175:41: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
173 |     }
174 |
175 |     func sparkleNamespacedName(of node: XMLNode) -> String? {
    |                                         `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
176 |         // XML namespace prefix is semantically meaningless, so compare namespace URI
177 |         // NS URI isn't used to fetch anything, and must match exactly, so we look for http:// not https://
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:192:30: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
190 |     static let SUXMLLanguage = "xml:lang"
191 |
192 |     func bestNode(in nodes: [XMLNode], name: String) -> XMLNode? {
    |                              `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
193 |         // We use this method to pick out the localized version of a node when one's available.
194 |         if nodes.count == 1 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:192:57: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
190 |     static let SUXMLLanguage = "xml:lang"
191 |
192 |     func bestNode(in nodes: [XMLNode], name: String) -> XMLNode? {
    |                                                         `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
193 |         // We use this method to pick out the localized version of a node when one's available.
194 |         if nodes.count == 1 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:227:30: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
225 |     typealias AttributesDictionary = [String: String]
226 |
227 |     func attributes(of node: XMLNode) -> AttributesDictionary {
    |                              `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
228 |         var dictionary = [String: String]()
229 |
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
[4/16] Compiling Appcast SUSignatures.swift
[5/16] Compiling Appcast SUVersionComparison.swift
[6/16] Compiling Appcast SUStandardVersionComparator.swift
[7/16] Compiling Appcast Appcast.swift
[8/16] Compiling Appcast Constants.swift
[9/16] Compiling Appcast SPUDownloadData.swift
[10/16] Compiling Appcast SPUSkippedUpdate.swift
[11/16] Compiling Appcast SPUAppcastItemState.swift
[12/16] Compiling Appcast SPUAppcastItemStateResolver.swift
[13/16] Compiling Appcast SUAppcastItem.swift
[14/16] Compiling Appcast SUOperatingSystem.swift
[15/16] Compiling Appcast SUAppcast.swift
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:175:41: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
173 |     }
174 |
175 |     func sparkleNamespacedName(of node: XMLNode) -> String? {
    |                                         `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
176 |         // XML namespace prefix is semantically meaningless, so compare namespace URI
177 |         // NS URI isn't used to fetch anything, and must match exactly, so we look for http:// not https://
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:192:30: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
190 |     static let SUXMLLanguage = "xml:lang"
191 |
192 |     func bestNode(in nodes: [XMLNode], name: String) -> XMLNode? {
    |                              `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
193 |         // We use this method to pick out the localized version of a node when one's available.
194 |         if nodes.count == 1 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:192:57: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
190 |     static let SUXMLLanguage = "xml:lang"
191 |
192 |     func bestNode(in nodes: [XMLNode], name: String) -> XMLNode? {
    |                                                         `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
193 |         // We use this method to pick out the localized version of a node when one's available.
194 |         if nodes.count == 1 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:227:30: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
225 |     typealias AttributesDictionary = [String: String]
226 |
227 |     func attributes(of node: XMLNode) -> AttributesDictionary {
    |                              `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
228 |         var dictionary = [String: String]()
229 |
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:27:28: error: 'XMLDocument' (aka 'AnyObject') cannot be constructed because it has no accessible initializers
 25 |         self.items = []
 26 |
 27 |         let document = try XMLDocument(data: appcastData, options: .nodeLoadExternalEntitiesNever)
    |                            `- error: 'XMLDocument' (aka 'AnyObject') cannot be constructed because it has no accessible initializers
 28 |         let xmlItems = try document.nodes(forXPath: "/rss/channel/item")
 29 |
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:27:69: error: cannot infer contextual base in reference to member 'nodeLoadExternalEntitiesNever'
 25 |         self.items = []
 26 |
 27 |         let document = try XMLDocument(data: appcastData, options: .nodeLoadExternalEntitiesNever)
    |                                                                     `- error: cannot infer contextual base in reference to member 'nodeLoadExternalEntitiesNever'
 28 |         let xmlItems = try document.nodes(forXPath: "/rss/channel/item")
 29 |
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:48:39: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
 46 |         for item in xmlItems {
 47 |             var dict = SUAppcastItemProperties()
 48 |             var nodesDict = [String: [XMLNode]]()
    |                                       `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
 49 |
 50 |             if item.childCount > 0 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:96:46: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
 94 |                     // that's a risk we can avoid. We don't use the date anywhere other
 95 |                     // than it being accessible from SUAppcastItem
 96 |                     if let dateString = node.stringValue {
    |                                              `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
 97 |                         dict[name] = dateString
 98 |                     }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:101:47: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
 99 |                 }
100 |                 else if name == SURSSElement.Description {
101 |                     if let description = node.stringValue {
    |                                               `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
102 |                         let attributes = self.attributes(of: node)
103 |                         let descriptionFormat = attributes[SUAppcastAttribute.Format]
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:115:44: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
113 |                     var deltas = [[String: String]]()
114 |
115 |                     if let children = node.children {
    |                                            `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
116 |                         for child in children {
117 |                             if child.name == SURSSElement.Enclosure {
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:129:44: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
127 |                     var tags = [String]()
128 |
129 |                     if let children = node.children {
    |                                            `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
130 |                         for child in children {
131 |                             if let childName = child.name {
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:142:44: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
140 |                     var informationalUpdateVersions = SUAppcastItem.InformationalUpdateType()
141 |
142 |                     if let children = node.children {
    |                                            `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
143 |                         for child in children {
144 |                             if child.name == SUAppcastElement.Version {
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:162:47: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
160 |                 else {
161 |                     // add all other values as strings
162 |                     if let stringValue = node.stringValue?.trimmingCharacters(in: CharacterSet.whitespacesAndNewlines) {
    |                                               `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
163 |                         dict[name] = stringValue
164 |                     }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:178:17: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'uri'
176 |         // XML namespace prefix is semantically meaningless, so compare namespace URI
177 |         // NS URI isn't used to fetch anything, and must match exactly, so we look for http:// not https://
178 |         if node.uri == "http://www.andymatuschak.org/xml-namespaces/sparkle" {
    |                 `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'uri'
179 |             guard let localName = node.localName else {
180 |                 return nil
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:179:40: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'localName'
177 |         // NS URI isn't used to fetch anything, and must match exactly, so we look for http:// not https://
178 |         if node.uri == "http://www.andymatuschak.org/xml-namespaces/sparkle" {
179 |             guard let localName = node.localName else {
    |                                        `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'localName'
180 |                 return nil
181 |             }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:187:21: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'name'
185 |
186 |         // Backwards compatibility
187 |         return node.name
    |                     `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'name'
188 |     }
189 |
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:203:38: warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
201 |         var languages = [String]()
202 |         for node in nodes {
203 |             guard let element = node as? XMLElement else {
    |                                      `- warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
204 |                 continue
205 |             }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:203:42: error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
201 |         var languages = [String]()
202 |         for node in nodes {
203 |             guard let element = node as? XMLElement else {
    |                                          `- error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
204 |                 continue
205 |             }
Foundation.XMLElement:2:18: note: 'XMLElement' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLElement = AnyObject
  |                  `- note: 'XMLElement' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:207:40: error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attribute'
205 |             }
206 |
207 |             let nodeLanguage = element.attribute(forName: SUAppcast.SUXMLLanguage)?.stringValue ?? ""
    |                                        `- error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attribute'
208 |             let language = nodeLanguage.isEmpty ? "en" : nodeLanguage
209 |             languages.append(language)
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:230:34: warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
228 |         var dictionary = [String: String]()
229 |
230 |         guard let element = node as? XMLElement else {
    |                                  `- warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
231 |             return dictionary
232 |         }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:230:38: error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
228 |         var dictionary = [String: String]()
229 |
230 |         guard let element = node as? XMLElement else {
    |                                      `- error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
231 |             return dictionary
232 |         }
Foundation.XMLElement:2:18: note: 'XMLElement' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLElement = AnyObject
  |                  `- note: 'XMLElement' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:234:40: error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attributes'
232 |         }
233 |
234 |         guard let attributes = element.attributes else {
    |                                        `- error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attributes'
235 |             return dictionary
236 |         }
[16/16] Compiling Appcast SUAppcastDriver.swift
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:175:41: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
173 |     }
174 |
175 |     func sparkleNamespacedName(of node: XMLNode) -> String? {
    |                                         `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
176 |         // XML namespace prefix is semantically meaningless, so compare namespace URI
177 |         // NS URI isn't used to fetch anything, and must match exactly, so we look for http:// not https://
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:192:30: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
190 |     static let SUXMLLanguage = "xml:lang"
191 |
192 |     func bestNode(in nodes: [XMLNode], name: String) -> XMLNode? {
    |                              `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
193 |         // We use this method to pick out the localized version of a node when one's available.
194 |         if nodes.count == 1 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:192:57: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
190 |     static let SUXMLLanguage = "xml:lang"
191 |
192 |     func bestNode(in nodes: [XMLNode], name: String) -> XMLNode? {
    |                                                         `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
193 |         // We use this method to pick out the localized version of a node when one's available.
194 |         if nodes.count == 1 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:227:30: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
225 |     typealias AttributesDictionary = [String: String]
226 |
227 |     func attributes(of node: XMLNode) -> AttributesDictionary {
    |                              `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
228 |         var dictionary = [String: String]()
229 |
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:27:28: error: 'XMLDocument' (aka 'AnyObject') cannot be constructed because it has no accessible initializers
 25 |         self.items = []
 26 |
 27 |         let document = try XMLDocument(data: appcastData, options: .nodeLoadExternalEntitiesNever)
    |                            `- error: 'XMLDocument' (aka 'AnyObject') cannot be constructed because it has no accessible initializers
 28 |         let xmlItems = try document.nodes(forXPath: "/rss/channel/item")
 29 |
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:27:69: error: cannot infer contextual base in reference to member 'nodeLoadExternalEntitiesNever'
 25 |         self.items = []
 26 |
 27 |         let document = try XMLDocument(data: appcastData, options: .nodeLoadExternalEntitiesNever)
    |                                                                     `- error: cannot infer contextual base in reference to member 'nodeLoadExternalEntitiesNever'
 28 |         let xmlItems = try document.nodes(forXPath: "/rss/channel/item")
 29 |
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:48:39: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
 46 |         for item in xmlItems {
 47 |             var dict = SUAppcastItemProperties()
 48 |             var nodesDict = [String: [XMLNode]]()
    |                                       `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
 49 |
 50 |             if item.childCount > 0 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:96:46: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
 94 |                     // that's a risk we can avoid. We don't use the date anywhere other
 95 |                     // than it being accessible from SUAppcastItem
 96 |                     if let dateString = node.stringValue {
    |                                              `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
 97 |                         dict[name] = dateString
 98 |                     }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:101:47: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
 99 |                 }
100 |                 else if name == SURSSElement.Description {
101 |                     if let description = node.stringValue {
    |                                               `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
102 |                         let attributes = self.attributes(of: node)
103 |                         let descriptionFormat = attributes[SUAppcastAttribute.Format]
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:115:44: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
113 |                     var deltas = [[String: String]]()
114 |
115 |                     if let children = node.children {
    |                                            `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
116 |                         for child in children {
117 |                             if child.name == SURSSElement.Enclosure {
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:129:44: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
127 |                     var tags = [String]()
128 |
129 |                     if let children = node.children {
    |                                            `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
130 |                         for child in children {
131 |                             if let childName = child.name {
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:142:44: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
140 |                     var informationalUpdateVersions = SUAppcastItem.InformationalUpdateType()
141 |
142 |                     if let children = node.children {
    |                                            `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
143 |                         for child in children {
144 |                             if child.name == SUAppcastElement.Version {
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:162:47: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
160 |                 else {
161 |                     // add all other values as strings
162 |                     if let stringValue = node.stringValue?.trimmingCharacters(in: CharacterSet.whitespacesAndNewlines) {
    |                                               `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
163 |                         dict[name] = stringValue
164 |                     }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:178:17: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'uri'
176 |         // XML namespace prefix is semantically meaningless, so compare namespace URI
177 |         // NS URI isn't used to fetch anything, and must match exactly, so we look for http:// not https://
178 |         if node.uri == "http://www.andymatuschak.org/xml-namespaces/sparkle" {
    |                 `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'uri'
179 |             guard let localName = node.localName else {
180 |                 return nil
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:179:40: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'localName'
177 |         // NS URI isn't used to fetch anything, and must match exactly, so we look for http:// not https://
178 |         if node.uri == "http://www.andymatuschak.org/xml-namespaces/sparkle" {
179 |             guard let localName = node.localName else {
    |                                        `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'localName'
180 |                 return nil
181 |             }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:187:21: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'name'
185 |
186 |         // Backwards compatibility
187 |         return node.name
    |                     `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'name'
188 |     }
189 |
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:203:38: warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
201 |         var languages = [String]()
202 |         for node in nodes {
203 |             guard let element = node as? XMLElement else {
    |                                      `- warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
204 |                 continue
205 |             }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:203:42: error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
201 |         var languages = [String]()
202 |         for node in nodes {
203 |             guard let element = node as? XMLElement else {
    |                                          `- error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
204 |                 continue
205 |             }
Foundation.XMLElement:2:18: note: 'XMLElement' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLElement = AnyObject
  |                  `- note: 'XMLElement' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:207:40: error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attribute'
205 |             }
206 |
207 |             let nodeLanguage = element.attribute(forName: SUAppcast.SUXMLLanguage)?.stringValue ?? ""
    |                                        `- error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attribute'
208 |             let language = nodeLanguage.isEmpty ? "en" : nodeLanguage
209 |             languages.append(language)
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:230:34: warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
228 |         var dictionary = [String: String]()
229 |
230 |         guard let element = node as? XMLElement else {
    |                                  `- warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
231 |             return dictionary
232 |         }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:230:38: error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
228 |         var dictionary = [String: String]()
229 |
230 |         guard let element = node as? XMLElement else {
    |                                      `- error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
231 |             return dictionary
232 |         }
Foundation.XMLElement:2:18: note: 'XMLElement' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLElement = AnyObject
  |                  `- note: 'XMLElement' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:234:40: error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attributes'
232 |         }
233 |
234 |         guard let attributes = element.attributes else {
    |                                        `- error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attributes'
235 |             return dictionary
236 |         }
Running build ...
bash -c docker run --pull=always --rm -v "checkouts-4606859-0":/host -w "$PWD" registry.gitlab.com/finestructure/spi-images:basic-6.0-latest swift build --triple x86_64-unknown-linux-gnu 2>&1
basic-6.0-latest: Pulling from finestructure/spi-images
Digest: sha256:9029076bb687edc160a3d5201c89e92dd9fa7309f33f090c4234365c83366c31
Status: Image is up to date for registry.gitlab.com/finestructure/spi-images:basic-6.0-latest
[0/1] Planning build
Building for debugging...
[0/1] Write swift-version-24593BA9C3E375BF.txt
error: emit-module command failed with exit code 1 (use -v to see invocation)
[2/14] Compiling Appcast Appcast.swift
[3/14] Compiling Appcast Constants.swift
[4/14] Emitting module Appcast
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:175:41: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
173 |     }
174 |
175 |     func sparkleNamespacedName(of node: XMLNode) -> String? {
    |                                         `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
176 |         // XML namespace prefix is semantically meaningless, so compare namespace URI
177 |         // NS URI isn't used to fetch anything, and must match exactly, so we look for http:// not https://
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:192:30: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
190 |     static let SUXMLLanguage = "xml:lang"
191 |
192 |     func bestNode(in nodes: [XMLNode], name: String) -> XMLNode? {
    |                              `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
193 |         // We use this method to pick out the localized version of a node when one's available.
194 |         if nodes.count == 1 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:192:57: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
190 |     static let SUXMLLanguage = "xml:lang"
191 |
192 |     func bestNode(in nodes: [XMLNode], name: String) -> XMLNode? {
    |                                                         `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
193 |         // We use this method to pick out the localized version of a node when one's available.
194 |         if nodes.count == 1 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:227:30: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
225 |     typealias AttributesDictionary = [String: String]
226 |
227 |     func attributes(of node: XMLNode) -> AttributesDictionary {
    |                              `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
228 |         var dictionary = [String: String]()
229 |
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
[5/15] Compiling Appcast SUVersionComparison.swift
[6/15] Compiling Appcast SPUAppcastItemState.swift
[7/15] Compiling Appcast SPUAppcastItemStateResolver.swift
[8/15] Compiling Appcast SUSignatures.swift
[9/15] Compiling Appcast SUStandardVersionComparator.swift
[10/15] Compiling Appcast SPUDownloadData.swift
[11/15] Compiling Appcast SPUSkippedUpdate.swift
[12/15] Compiling Appcast SUAppcastItem.swift
[13/15] Compiling Appcast SUOperatingSystem.swift
[14/15] Compiling Appcast SUAppcast.swift
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:175:41: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
173 |     }
174 |
175 |     func sparkleNamespacedName(of node: XMLNode) -> String? {
    |                                         `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
176 |         // XML namespace prefix is semantically meaningless, so compare namespace URI
177 |         // NS URI isn't used to fetch anything, and must match exactly, so we look for http:// not https://
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:192:30: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
190 |     static let SUXMLLanguage = "xml:lang"
191 |
192 |     func bestNode(in nodes: [XMLNode], name: String) -> XMLNode? {
    |                              `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
193 |         // We use this method to pick out the localized version of a node when one's available.
194 |         if nodes.count == 1 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:192:57: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
190 |     static let SUXMLLanguage = "xml:lang"
191 |
192 |     func bestNode(in nodes: [XMLNode], name: String) -> XMLNode? {
    |                                                         `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
193 |         // We use this method to pick out the localized version of a node when one's available.
194 |         if nodes.count == 1 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:227:30: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
225 |     typealias AttributesDictionary = [String: String]
226 |
227 |     func attributes(of node: XMLNode) -> AttributesDictionary {
    |                              `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
228 |         var dictionary = [String: String]()
229 |
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:27:28: error: 'XMLDocument' (aka 'AnyObject') cannot be constructed because it has no accessible initializers
 25 |         self.items = []
 26 |
 27 |         let document = try XMLDocument(data: appcastData, options: .nodeLoadExternalEntitiesNever)
    |                            `- error: 'XMLDocument' (aka 'AnyObject') cannot be constructed because it has no accessible initializers
 28 |         let xmlItems = try document.nodes(forXPath: "/rss/channel/item")
 29 |
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:27:69: error: cannot infer contextual base in reference to member 'nodeLoadExternalEntitiesNever'
 25 |         self.items = []
 26 |
 27 |         let document = try XMLDocument(data: appcastData, options: .nodeLoadExternalEntitiesNever)
    |                                                                     `- error: cannot infer contextual base in reference to member 'nodeLoadExternalEntitiesNever'
 28 |         let xmlItems = try document.nodes(forXPath: "/rss/channel/item")
 29 |
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:48:39: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
 46 |         for item in xmlItems {
 47 |             var dict = SUAppcastItemProperties()
 48 |             var nodesDict = [String: [XMLNode]]()
    |                                       `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
 49 |
 50 |             if item.childCount > 0 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:96:46: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
 94 |                     // that's a risk we can avoid. We don't use the date anywhere other
 95 |                     // than it being accessible from SUAppcastItem
 96 |                     if let dateString = node.stringValue {
    |                                              `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
 97 |                         dict[name] = dateString
 98 |                     }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:101:47: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
 99 |                 }
100 |                 else if name == SURSSElement.Description {
101 |                     if let description = node.stringValue {
    |                                               `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
102 |                         let attributes = self.attributes(of: node)
103 |                         let descriptionFormat = attributes[SUAppcastAttribute.Format]
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:115:44: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
113 |                     var deltas = [[String: String]]()
114 |
115 |                     if let children = node.children {
    |                                            `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
116 |                         for child in children {
117 |                             if child.name == SURSSElement.Enclosure {
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:129:44: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
127 |                     var tags = [String]()
128 |
129 |                     if let children = node.children {
    |                                            `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
130 |                         for child in children {
131 |                             if let childName = child.name {
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:142:44: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
140 |                     var informationalUpdateVersions = SUAppcastItem.InformationalUpdateType()
141 |
142 |                     if let children = node.children {
    |                                            `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
143 |                         for child in children {
144 |                             if child.name == SUAppcastElement.Version {
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:162:47: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
160 |                 else {
161 |                     // add all other values as strings
162 |                     if let stringValue = node.stringValue?.trimmingCharacters(in: CharacterSet.whitespacesAndNewlines) {
    |                                               `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
163 |                         dict[name] = stringValue
164 |                     }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:178:17: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'uri'
176 |         // XML namespace prefix is semantically meaningless, so compare namespace URI
177 |         // NS URI isn't used to fetch anything, and must match exactly, so we look for http:// not https://
178 |         if node.uri == "http://www.andymatuschak.org/xml-namespaces/sparkle" {
    |                 `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'uri'
179 |             guard let localName = node.localName else {
180 |                 return nil
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:179:40: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'localName'
177 |         // NS URI isn't used to fetch anything, and must match exactly, so we look for http:// not https://
178 |         if node.uri == "http://www.andymatuschak.org/xml-namespaces/sparkle" {
179 |             guard let localName = node.localName else {
    |                                        `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'localName'
180 |                 return nil
181 |             }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:187:21: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'name'
185 |
186 |         // Backwards compatibility
187 |         return node.name
    |                     `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'name'
188 |     }
189 |
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:203:38: warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
201 |         var languages = [String]()
202 |         for node in nodes {
203 |             guard let element = node as? XMLElement else {
    |                                      `- warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
204 |                 continue
205 |             }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:203:42: error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
201 |         var languages = [String]()
202 |         for node in nodes {
203 |             guard let element = node as? XMLElement else {
    |                                          `- error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
204 |                 continue
205 |             }
Foundation.XMLElement:2:18: note: 'XMLElement' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLElement = AnyObject
  |                  `- note: 'XMLElement' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:207:40: error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attribute'
205 |             }
206 |
207 |             let nodeLanguage = element.attribute(forName: SUAppcast.SUXMLLanguage)?.stringValue ?? ""
    |                                        `- error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attribute'
208 |             let language = nodeLanguage.isEmpty ? "en" : nodeLanguage
209 |             languages.append(language)
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:230:34: warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
228 |         var dictionary = [String: String]()
229 |
230 |         guard let element = node as? XMLElement else {
    |                                  `- warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
231 |             return dictionary
232 |         }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:230:38: error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
228 |         var dictionary = [String: String]()
229 |
230 |         guard let element = node as? XMLElement else {
    |                                      `- error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
231 |             return dictionary
232 |         }
Foundation.XMLElement:2:18: note: 'XMLElement' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLElement = AnyObject
  |                  `- note: 'XMLElement' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:234:40: error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attributes'
232 |         }
233 |
234 |         guard let attributes = element.attributes else {
    |                                        `- error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attributes'
235 |             return dictionary
236 |         }
[15/15] Compiling Appcast SUAppcastDriver.swift
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:175:41: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
173 |     }
174 |
175 |     func sparkleNamespacedName(of node: XMLNode) -> String? {
    |                                         `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
176 |         // XML namespace prefix is semantically meaningless, so compare namespace URI
177 |         // NS URI isn't used to fetch anything, and must match exactly, so we look for http:// not https://
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:192:30: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
190 |     static let SUXMLLanguage = "xml:lang"
191 |
192 |     func bestNode(in nodes: [XMLNode], name: String) -> XMLNode? {
    |                              `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
193 |         // We use this method to pick out the localized version of a node when one's available.
194 |         if nodes.count == 1 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:192:57: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
190 |     static let SUXMLLanguage = "xml:lang"
191 |
192 |     func bestNode(in nodes: [XMLNode], name: String) -> XMLNode? {
    |                                                         `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
193 |         // We use this method to pick out the localized version of a node when one's available.
194 |         if nodes.count == 1 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:227:30: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
225 |     typealias AttributesDictionary = [String: String]
226 |
227 |     func attributes(of node: XMLNode) -> AttributesDictionary {
    |                              `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
228 |         var dictionary = [String: String]()
229 |
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:27:28: error: 'XMLDocument' (aka 'AnyObject') cannot be constructed because it has no accessible initializers
 25 |         self.items = []
 26 |
 27 |         let document = try XMLDocument(data: appcastData, options: .nodeLoadExternalEntitiesNever)
    |                            `- error: 'XMLDocument' (aka 'AnyObject') cannot be constructed because it has no accessible initializers
 28 |         let xmlItems = try document.nodes(forXPath: "/rss/channel/item")
 29 |
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:27:69: error: cannot infer contextual base in reference to member 'nodeLoadExternalEntitiesNever'
 25 |         self.items = []
 26 |
 27 |         let document = try XMLDocument(data: appcastData, options: .nodeLoadExternalEntitiesNever)
    |                                                                     `- error: cannot infer contextual base in reference to member 'nodeLoadExternalEntitiesNever'
 28 |         let xmlItems = try document.nodes(forXPath: "/rss/channel/item")
 29 |
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:48:39: error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
 46 |         for item in xmlItems {
 47 |             var dict = SUAppcastItemProperties()
 48 |             var nodesDict = [String: [XMLNode]]()
    |                                       `- error: 'XMLNode' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
 49 |
 50 |             if item.childCount > 0 {
Foundation.XMLNode:2:18: note: 'XMLNode' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLNode = AnyObject
  |                  `- note: 'XMLNode' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:96:46: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
 94 |                     // that's a risk we can avoid. We don't use the date anywhere other
 95 |                     // than it being accessible from SUAppcastItem
 96 |                     if let dateString = node.stringValue {
    |                                              `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
 97 |                         dict[name] = dateString
 98 |                     }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:101:47: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
 99 |                 }
100 |                 else if name == SURSSElement.Description {
101 |                     if let description = node.stringValue {
    |                                               `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
102 |                         let attributes = self.attributes(of: node)
103 |                         let descriptionFormat = attributes[SUAppcastAttribute.Format]
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:115:44: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
113 |                     var deltas = [[String: String]]()
114 |
115 |                     if let children = node.children {
    |                                            `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
116 |                         for child in children {
117 |                             if child.name == SURSSElement.Enclosure {
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:129:44: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
127 |                     var tags = [String]()
128 |
129 |                     if let children = node.children {
    |                                            `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
130 |                         for child in children {
131 |                             if let childName = child.name {
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:142:44: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
140 |                     var informationalUpdateVersions = SUAppcastItem.InformationalUpdateType()
141 |
142 |                     if let children = node.children {
    |                                            `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'children'
143 |                         for child in children {
144 |                             if child.name == SUAppcastElement.Version {
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:162:47: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
160 |                 else {
161 |                     // add all other values as strings
162 |                     if let stringValue = node.stringValue?.trimmingCharacters(in: CharacterSet.whitespacesAndNewlines) {
    |                                               `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'stringValue'
163 |                         dict[name] = stringValue
164 |                     }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:178:17: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'uri'
176 |         // XML namespace prefix is semantically meaningless, so compare namespace URI
177 |         // NS URI isn't used to fetch anything, and must match exactly, so we look for http:// not https://
178 |         if node.uri == "http://www.andymatuschak.org/xml-namespaces/sparkle" {
    |                 `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'uri'
179 |             guard let localName = node.localName else {
180 |                 return nil
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:179:40: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'localName'
177 |         // NS URI isn't used to fetch anything, and must match exactly, so we look for http:// not https://
178 |         if node.uri == "http://www.andymatuschak.org/xml-namespaces/sparkle" {
179 |             guard let localName = node.localName else {
    |                                        `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'localName'
180 |                 return nil
181 |             }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:187:21: error: value of type 'XMLNode' (aka 'AnyObject') has no member 'name'
185 |
186 |         // Backwards compatibility
187 |         return node.name
    |                     `- error: value of type 'XMLNode' (aka 'AnyObject') has no member 'name'
188 |     }
189 |
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:203:38: warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
201 |         var languages = [String]()
202 |         for node in nodes {
203 |             guard let element = node as? XMLElement else {
    |                                      `- warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
204 |                 continue
205 |             }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:203:42: error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
201 |         var languages = [String]()
202 |         for node in nodes {
203 |             guard let element = node as? XMLElement else {
    |                                          `- error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
204 |                 continue
205 |             }
Foundation.XMLElement:2:18: note: 'XMLElement' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLElement = AnyObject
  |                  `- note: 'XMLElement' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:207:40: error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attribute'
205 |             }
206 |
207 |             let nodeLanguage = element.attribute(forName: SUAppcast.SUXMLLanguage)?.stringValue ?? ""
    |                                        `- error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attribute'
208 |             let language = nodeLanguage.isEmpty ? "en" : nodeLanguage
209 |             languages.append(language)
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:230:34: warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
228 |         var dictionary = [String: String]()
229 |
230 |         guard let element = node as? XMLElement else {
    |                                  `- warning: conditional cast from 'XMLNode' (aka 'AnyObject') to 'XMLElement' (aka 'AnyObject') always succeeds
231 |             return dictionary
232 |         }
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:230:38: error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
228 |         var dictionary = [String: String]()
229 |
230 |         guard let element = node as? XMLElement else {
    |                                      `- error: 'XMLElement' is unavailable: This type has moved to the FoundationXML module. Import that module to use it.
231 |             return dictionary
232 |         }
Foundation.XMLElement:2:18: note: 'XMLElement' has been explicitly marked unavailable here
1 | @available(*, unavailable, message: "This type has moved to the FoundationXML module. Import that module to use it.")
2 | public typealias XMLElement = AnyObject
  |                  `- note: 'XMLElement' has been explicitly marked unavailable here
/host/spi-builder-workspace/Sources/Appcast/SUAppcast.swift:234:40: error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attributes'
232 |         }
233 |
234 |         guard let attributes = element.attributes else {
    |                                        `- error: value of type 'XMLElement' (aka 'AnyObject') has no member 'attributes'
235 |             return dictionary
236 |         }
BUILD FAILURE 6.0 linux