From c8289b126db37112f13c25c6c96a92cdc738c9ed Mon Sep 17 00:00:00 2001 From: Anders Bertelrud Date: Wed, 21 Jun 2023 16:42:12 -0700 Subject: [PATCH] Add `visionOS` as a platform alongside `iOS`, `tvOS`, `watchOS`, and the others (#6662) Add new enum constants for visionOS in all the places where it is appropriate. This includes the `platforms` parameter in the manifest, whose purpose is to list the minimum deployment targets that a package requires. Since there is initially only visionOS 1.0, and because absence of a platform in the `platforms` parameter means that the default version is supported (not that the platform is unsupported), all packages implicitly support visionOS 1.0 whether or not they list it in the `platforms` parameter. But having the enum constant alongside those for the other Apple platforms makes everything consistent, and will become important for any future versions. This change also makes the `visionOS` platform available for use in conditional target dependencies. rdar://107064954 (cherry picked from commit 809cb152a303926b243edb09ba4f0590e4b0c8b7) --- .../JSONPackageCollectionProvider.swift | 2 + .../Curation/SupportedPlatforms.md | 7 +++ .../SupportedPlatforms.swift | 49 +++++++++++++++++++ .../ManifestSourceGeneration.swift | 3 ++ .../MinimumDeploymentTarget.swift | 2 + Sources/PackageModel/Platform.swift | 1 + Sources/PackageModel/PlatformRegistry.swift | 2 +- Sources/Workspace/InitPackage.swift | 4 ++ Sources/XCBuildSupport/PIF.swift | 1 + Sources/XCBuildSupport/PIFBuilder.swift | 2 + .../PackageGraphTests/PackageGraphTests.swift | 3 ++ .../PD_5_9_LoadingTests.swift | 3 +- .../ManifestSourceGenerationTests.swift | 5 +- .../XCBuildSupportTests/PIFBuilderTests.swift | 8 +++ 14 files changed, 88 insertions(+), 4 deletions(-) diff --git a/Sources/PackageCollections/Providers/JSONPackageCollectionProvider.swift b/Sources/PackageCollections/Providers/JSONPackageCollectionProvider.swift index b2aafbce3b3..4067780c662 100644 --- a/Sources/PackageCollections/Providers/JSONPackageCollectionProvider.swift +++ b/Sources/PackageCollections/Providers/JSONPackageCollectionProvider.swift @@ -480,6 +480,8 @@ extension PackageModel.Platform { self = PackageModel.Platform.tvOS case let name where name.contains("watchos"): self = PackageModel.Platform.watchOS + case let name where name.contains("visionos"): + self = PackageModel.Platform.visionOS case let name where name.contains("driverkit"): self = PackageModel.Platform.driverKit case let name where name.contains("linux"): diff --git a/Sources/PackageDescription/PackageDescription.docc/Curation/SupportedPlatforms.md b/Sources/PackageDescription/PackageDescription.docc/Curation/SupportedPlatforms.md index 6a1a3e1928c..e30d3c1b50b 100644 --- a/Sources/PackageDescription/PackageDescription.docc/Curation/SupportedPlatforms.md +++ b/Sources/PackageDescription/PackageDescription.docc/Curation/SupportedPlatforms.md @@ -23,6 +23,13 @@ - - ``WatchOSVersion`` +### Supporting visionOS + +- ``visionOS(_:)-3ip0z`` +- ``visionOS(_:)-6ur2u`` +- +- ``VisionOSVersion`` + ### Supporting tvOS - ``tvOS(_:)-6931l`` diff --git a/Sources/PackageDescription/SupportedPlatforms.swift b/Sources/PackageDescription/SupportedPlatforms.swift index c876bdd9691..be1ee1462a5 100644 --- a/Sources/PackageDescription/SupportedPlatforms.swift +++ b/Sources/PackageDescription/SupportedPlatforms.swift @@ -45,6 +45,9 @@ public struct Platform: Equatable { /// The watchOS platform. public static let watchOS: Platform = Platform(name: "watchos") + /// The visionOS platform. + public static let visionOS: Platform = Platform(name: "visionos") + /// The DriverKit platform public static let driverKit: Platform = Platform(name: "driverkit") @@ -224,6 +227,33 @@ public struct SupportedPlatform: Equatable { return SupportedPlatform(platform: .watchOS, version: SupportedPlatform.WatchOSVersion(string: versionString).version) } + /// Configure the minimum deployment target version for the visionOS + /// platform. + /// + /// - Since: First available in PackageDescription 5.9 + /// + /// - Parameter version: The minimum deployment target that the package supports. + /// - Returns: A `SupportedPlatform` instance. + @available(_PackageDescription, introduced: 5.9) + public static func visionOS(_ version: SupportedPlatform.VisionOSVersion) -> SupportedPlatform { + return SupportedPlatform(platform: .visionOS, version: version.version) + } + + /// Configure the minimum deployment target version for the visionOS + /// platform using a custom version string. + /// + /// The version string must be a series of two or three dot-separated integers, such as `1.0` or `1.0.0`. + /// + /// - Since: First available in PackageDescription 5.9 + /// + /// - Parameter versionString: The minimum deployment target as a string + /// representation of two or three dot-separated integers, such as `1.0.0`. + /// - Returns: A `SupportedPlatform` instance. + @available(_PackageDescription, introduced: 5.9) + public static func visionOS(_ versionString: String) -> SupportedPlatform { + return SupportedPlatform(platform: .visionOS, version: SupportedPlatform.VisionOSVersion(string: versionString).version) + } + /// Configures the minimum deployment target version for the DriverKit platform. /// /// - Parameter version: The minimum deployment target that the package supports. @@ -594,6 +624,25 @@ extension SupportedPlatform { public static let v10: WatchOSVersion = .init(string: "10.0") } + /// The supported visionOS version. + public struct VisionOSVersion: AppleOSVersion { + fileprivate static let name = "visionOS" + fileprivate static let minimumMajorVersion = 1 + + /// The underlying version representation. + let version: String + + fileprivate init(uncheckedVersion version: String) { + self.version = version + } + + /// The value that represents visionOS 1.0. + /// + /// - Since: First available in PackageDescription 5.9. + @available(_PackageDescription, introduced: 5.9) + public static let v1: VisionOSVersion = .init(string: "1.0") + } + /// The supported DriverKit version. public struct DriverKitVersion: AppleOSVersion { fileprivate static let name = "DriverKit" diff --git a/Sources/PackageModel/ManifestSourceGeneration.swift b/Sources/PackageModel/ManifestSourceGeneration.swift index 5124345309e..2838b67f3bb 100644 --- a/Sources/PackageModel/ManifestSourceGeneration.swift +++ b/Sources/PackageModel/ManifestSourceGeneration.swift @@ -142,6 +142,8 @@ fileprivate extension SourceCodeFragment { self.init(enum: "tvOS", string: platform.version) case "watchos": self.init(enum: "watchOS", string: platform.version) + case "visionos": + self.init(enum: "visionOS", string: platform.version) case "driverkit": self.init(enum: "driverKit", string: platform.version) default: @@ -367,6 +369,7 @@ fileprivate extension SourceCodeFragment { case "ios": return SourceCodeFragment(enum: "iOS") case "tvos": return SourceCodeFragment(enum: "tvOS") case "watchos": return SourceCodeFragment(enum: "watchOS") + case "visionos": return SourceCodeFragment(enum: "visionOS") case "driverkit": return SourceCodeFragment(enum: "driverKit") default: return SourceCodeFragment(enum: platformName) } diff --git a/Sources/PackageModel/MinimumDeploymentTarget.swift b/Sources/PackageModel/MinimumDeploymentTarget.swift index 6b990578f9c..2cade2a3adf 100644 --- a/Sources/PackageModel/MinimumDeploymentTarget.swift +++ b/Sources/PackageModel/MinimumDeploymentTarget.swift @@ -81,6 +81,8 @@ private extension PackageModel.Platform { return ("appletvos", "TVOS") case .watchOS: return ("watchos", "WATCHOS") + case .visionOS: + return ("xros", "XROS") case .driverKit: return nil // DriverKit does not support XCTest. default: diff --git a/Sources/PackageModel/Platform.swift b/Sources/PackageModel/Platform.swift index 68e0874f905..54613a266e1 100644 --- a/Sources/PackageModel/Platform.swift +++ b/Sources/PackageModel/Platform.swift @@ -38,6 +38,7 @@ public struct Platform: Equatable, Hashable, Codable { public static let iOS: Platform = Platform(name: "ios", oldestSupportedVersion: "11.0") public static let tvOS: Platform = Platform(name: "tvos", oldestSupportedVersion: "11.0") public static let watchOS: Platform = Platform(name: "watchos", oldestSupportedVersion: "4.0") + public static let visionOS: Platform = Platform(name: "visionos", oldestSupportedVersion: "1.0") public static let driverKit: Platform = Platform(name: "driverkit", oldestSupportedVersion: "19.0") public static let linux: Platform = Platform(name: "linux", oldestSupportedVersion: .unknown) public static let android: Platform = Platform(name: "android", oldestSupportedVersion: .unknown) diff --git a/Sources/PackageModel/PlatformRegistry.swift b/Sources/PackageModel/PlatformRegistry.swift index aec0321d51b..c56864b292b 100644 --- a/Sources/PackageModel/PlatformRegistry.swift +++ b/Sources/PackageModel/PlatformRegistry.swift @@ -31,6 +31,6 @@ public final class PlatformRegistry { /// The static list of known platforms. private static var _knownPlatforms: [Platform] { - return [.macOS, .macCatalyst, .iOS, .tvOS, .watchOS, .linux, .windows, .android, .wasi, .driverKit, .openbsd] + return [.macOS, .macCatalyst, .iOS, .tvOS, .watchOS, .visionOS, .linux, .windows, .android, .wasi, .driverKit, .openbsd] } } diff --git a/Sources/Workspace/InitPackage.swift b/Sources/Workspace/InitPackage.swift index 5f582feb644..dba81875503 100644 --- a/Sources/Workspace/InitPackage.swift +++ b/Sources/Workspace/InitPackage.swift @@ -781,6 +781,8 @@ extension PackageModel.Platform { return "tvOS" case .watchOS: return "watchOS" + case .visionOS: + return "visionOS" case .driverKit: return "DriverKit" default: @@ -816,6 +818,8 @@ extension SupportedPlatform { return (9...14).contains(version.major) case .watchOS: return (2...7).contains(version.major) + case .visionOS: + return (1...1).contains(version.major) case .driverKit: return (19...20).contains(version.major) diff --git a/Sources/XCBuildSupport/PIF.swift b/Sources/XCBuildSupport/PIF.swift index b4345527d07..9fa78c1b9f8 100644 --- a/Sources/XCBuildSupport/PIF.swift +++ b/Sources/XCBuildSupport/PIF.swift @@ -953,6 +953,7 @@ public enum PIF { case USE_HEADERMAP case USES_SWIFTPM_UNSAFE_FLAGS case WATCHOS_DEPLOYMENT_TARGET + case XROS_DEPLOYMENT_TARGET case MARKETING_VERSION case CURRENT_PROJECT_VERSION case SWIFT_EMIT_MODULE_INTERFACE diff --git a/Sources/XCBuildSupport/PIFBuilder.swift b/Sources/XCBuildSupport/PIFBuilder.swift index 7f3b25c3cb9..215a07983d7 100644 --- a/Sources/XCBuildSupport/PIFBuilder.swift +++ b/Sources/XCBuildSupport/PIFBuilder.swift @@ -273,6 +273,7 @@ final class PackagePIFProjectBuilder: PIFProjectBuilder { settings[.IPHONEOS_DEPLOYMENT_TARGET, for: .macCatalyst] = package.platforms.deploymentTarget(for: .macCatalyst) settings[.TVOS_DEPLOYMENT_TARGET] = package.platforms.deploymentTarget(for: .tvOS) settings[.WATCHOS_DEPLOYMENT_TARGET] = package.platforms.deploymentTarget(for: .watchOS) + settings[.XROS_DEPLOYMENT_TARGET] = package.platforms.deploymentTarget(for: .visionOS) settings[.DRIVERKIT_DEPLOYMENT_TARGET] = package.platforms.deploymentTarget(for: .driverKit) settings[.DYLIB_INSTALL_NAME_BASE] = "@rpath" settings[.USE_HEADERMAP] = "NO" @@ -430,6 +431,7 @@ final class PackagePIFProjectBuilder: PIFProjectBuilder { settings[.IPHONEOS_DEPLOYMENT_TARGET] = mainTarget.platforms.deploymentTarget(for: .iOS) settings[.TVOS_DEPLOYMENT_TARGET] = mainTarget.platforms.deploymentTarget(for: .tvOS) settings[.WATCHOS_DEPLOYMENT_TARGET] = mainTarget.platforms.deploymentTarget(for: .watchOS) + settings[.XROS_DEPLOYMENT_TARGET] = mainTarget.platforms.deploymentTarget(for: .visionOS) } if product.type == .executable { diff --git a/Tests/PackageGraphTests/PackageGraphTests.swift b/Tests/PackageGraphTests/PackageGraphTests.swift index b79b9fa8a6d..0490421ecab 100644 --- a/Tests/PackageGraphTests/PackageGraphTests.swift +++ b/Tests/PackageGraphTests/PackageGraphTests.swift @@ -2153,6 +2153,7 @@ class PackageGraphTests: XCTestCase { "tvos": "11.0", "driverkit": "19.0", "watchos": "4.0", + "visionos": "1.0", "android": "0.0", "windows": "0.0", "wasi": "0.0", @@ -2164,6 +2165,7 @@ class PackageGraphTests: XCTestCase { PackageModel.Platform.iOS: PlatformVersion("11.0"), PackageModel.Platform.tvOS: PlatformVersion("10.0"), PackageModel.Platform.watchOS: PlatformVersion("4.0"), + PackageModel.Platform.visionOS: PlatformVersion("1.0"), ] let expectedPlatformsForTests = customXCTestMinimumDeploymentTargets.reduce(into: [Platform : PlatformVersion]()) { partialResult, entry in @@ -2402,6 +2404,7 @@ class PackageGraphTests: XCTestCase { "tvos": "11.0", "driverkit": "19.0", "watchos": "4.0", + "visionos": "1.0", "android": "0.0", "windows": "0.0", "wasi": "0.0", diff --git a/Tests/PackageLoadingTests/PD_5_9_LoadingTests.swift b/Tests/PackageLoadingTests/PD_5_9_LoadingTests.swift index 0d04f876eb9..5890021a1f1 100644 --- a/Tests/PackageLoadingTests/PD_5_9_LoadingTests.swift +++ b/Tests/PackageLoadingTests/PD_5_9_LoadingTests.swift @@ -28,7 +28,7 @@ class PackageDescription5_9LoadingTests: PackageDescriptionLoadingTests { name: "Foo", platforms: [ .macOS(.v14), .iOS(.v17), - .tvOS(.v17), .watchOS(.v10), + .tvOS(.v17), .watchOS(.v10), .visionOS(.v1), .macCatalyst(.v17), .driverKit(.v23), ] ) @@ -44,6 +44,7 @@ class PackageDescription5_9LoadingTests: PackageDescriptionLoadingTests { PlatformDescription(name: "ios", version: "17.0"), PlatformDescription(name: "tvos", version: "17.0"), PlatformDescription(name: "watchos", version: "10.0"), + PlatformDescription(name: "visionos", version: "1.0"), PlatformDescription(name: "maccatalyst", version: "17.0"), PlatformDescription(name: "driverkit", version: "23.0"), ]) diff --git a/Tests/WorkspaceTests/ManifestSourceGenerationTests.swift b/Tests/WorkspaceTests/ManifestSourceGenerationTests.swift index fd84811e082..9f99d8831de 100644 --- a/Tests/WorkspaceTests/ManifestSourceGenerationTests.swift +++ b/Tests/WorkspaceTests/ManifestSourceGenerationTests.swift @@ -437,6 +437,7 @@ class ManifestSourceGenerationTests: XCTestCase { .iOS(.v17), .tvOS(.v17), .watchOS(.v10), + .visionOS(.v1), .macCatalyst(.v17), .driverKit(.v23) ], @@ -461,8 +462,8 @@ class ManifestSourceGenerationTests: XCTestCase { name: "MyExe", dependencies: [ .target(name: "MyLib", condition: .when(platforms: [ - .macOS, .macCatalyst, .iOS, .tvOS, .watchOS, .driverKit, - .linux, .windows, .android, .wasi, .openbsd + .macOS, .macCatalyst, .iOS, .tvOS, .watchOS, .visionOS, + .driverKit, .linux, .windows, .android, .wasi, .openbsd ])) ] ), diff --git a/Tests/XCBuildSupportTests/PIFBuilderTests.swift b/Tests/XCBuildSupportTests/PIFBuilderTests.swift index f1febda4390..e0065e57b94 100644 --- a/Tests/XCBuildSupportTests/PIFBuilderTests.swift +++ b/Tests/XCBuildSupportTests/PIFBuilderTests.swift @@ -204,6 +204,7 @@ class PIFBuilderTests: XCTestCase { XCTAssertEqual(settings[.TVOS_DEPLOYMENT_TARGET], "11.0") XCTAssertEqual(settings[.USE_HEADERMAP], "NO") XCTAssertEqual(settings[.WATCHOS_DEPLOYMENT_TARGET], "4.0") + XCTAssertEqual(settings[.XROS_DEPLOYMENT_TARGET], "1.0") let frameworksSearchPaths = ["$(inherited)", "$(PLATFORM_DIR)/Developer/Library/Frameworks"] for platform in [PIF.BuildSettings.Platform.macOS, .iOS, .tvOS] { @@ -249,6 +250,7 @@ class PIFBuilderTests: XCTestCase { XCTAssertEqual(settings[.TVOS_DEPLOYMENT_TARGET], "11.0") XCTAssertEqual(settings[.USE_HEADERMAP], "NO") XCTAssertEqual(settings[.WATCHOS_DEPLOYMENT_TARGET], "4.0") + XCTAssertEqual(settings[.XROS_DEPLOYMENT_TARGET], "1.0") let frameworksSearchPaths = ["$(inherited)", "$(PLATFORM_DIR)/Developer/Library/Frameworks"] for platform in [PIF.BuildSettings.Platform.macOS, .iOS, .tvOS] { @@ -306,6 +308,7 @@ class PIFBuilderTests: XCTestCase { XCTAssertEqual(settings[.TVOS_DEPLOYMENT_TARGET], "11.0") XCTAssertEqual(settings[.USE_HEADERMAP], "NO") XCTAssertEqual(settings[.WATCHOS_DEPLOYMENT_TARGET], "6.0") + XCTAssertEqual(settings[.XROS_DEPLOYMENT_TARGET], "1.0") let frameworksSearchPaths = ["$(inherited)", "$(PLATFORM_DIR)/Developer/Library/Frameworks"] for platform in [PIF.BuildSettings.Platform.macOS, .iOS, .tvOS] { @@ -351,6 +354,7 @@ class PIFBuilderTests: XCTestCase { XCTAssertEqual(settings[.TVOS_DEPLOYMENT_TARGET], "11.0") XCTAssertEqual(settings[.USE_HEADERMAP], "NO") XCTAssertEqual(settings[.WATCHOS_DEPLOYMENT_TARGET], "6.0") + XCTAssertEqual(settings[.XROS_DEPLOYMENT_TARGET], "1.0") let frameworksSearchPaths = ["$(inherited)", "$(PLATFORM_DIR)/Developer/Library/Frameworks"] for platform in [PIF.BuildSettings.Platform.macOS, .iOS, .tvOS] { @@ -836,6 +840,7 @@ class PIFBuilderTests: XCTestCase { XCTAssertEqual(settings[.IPHONEOS_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .iOS).versionString) XCTAssertEqual(settings[.TVOS_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .tvOS).versionString) XCTAssertEqual(settings[.MACOSX_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .macOS).versionString) + XCTAssertEqual(settings[.XROS_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .visionOS).versionString) } } @@ -868,6 +873,7 @@ class PIFBuilderTests: XCTestCase { XCTAssertEqual(settings[.IPHONEOS_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .iOS).versionString) XCTAssertEqual(settings[.TVOS_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .tvOS).versionString) XCTAssertEqual(settings[.MACOSX_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .macOS).versionString) + XCTAssertEqual(settings[.XROS_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .visionOS).versionString) } } @@ -914,6 +920,7 @@ class PIFBuilderTests: XCTestCase { XCTAssertEqual(settings[.IPHONEOS_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .iOS).versionString) XCTAssertEqual(settings[.TVOS_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .tvOS).versionString) XCTAssertEqual(settings[.MACOSX_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .macOS).versionString) + XCTAssertEqual(settings[.XROS_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .visionOS).versionString) } } @@ -949,6 +956,7 @@ class PIFBuilderTests: XCTestCase { XCTAssertEqual(settings[.IPHONEOS_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .iOS).versionString) XCTAssertEqual(settings[.TVOS_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .tvOS).versionString) XCTAssertEqual(settings[.MACOSX_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .macOS).versionString) + XCTAssertEqual(settings[.XROS_DEPLOYMENT_TARGET], MinimumDeploymentTarget.computeXCTestMinimumDeploymentTarget(for: .visionOS).versionString) } }