1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
|
//===----------------------------------------------------------------------===//
//
// This source file is part of the Swift open source project
//
// Copyright (c) 2014-2023 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See http://swift.org/LICENSE.txt for license information
// See http://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
/// Represents a manifest condition.
public struct PackageConditionDescription: Codable, Hashable, Sendable {
public let platformNames: [String]
public let config: String?
public init(platformNames: [String] = [], config: String? = nil) {
assert(!(platformNames.isEmpty && config == nil))
self.platformNames = platformNames
self.config = config
}
}
/// One of possible conditions used in package manifests to restrict modules from being built for certain platforms or
/// build configurations.
public enum PackageCondition: Hashable, Sendable {
case platforms(PlatformsCondition)
case configuration(ConfigurationCondition)
public func satisfies(_ environment: BuildEnvironment) -> Bool {
switch self {
case .configuration(let configuration):
return configuration.satisfies(environment)
case .platforms(let platforms):
return platforms.satisfies(environment)
}
}
public var platformsCondition: PlatformsCondition? {
guard case let .platforms(platformsCondition) = self else {
return nil
}
return platformsCondition
}
public var configurationCondition: ConfigurationCondition? {
guard case let .configuration(configurationCondition) = self else {
return nil
}
return configurationCondition
}
public init(platforms: [Platform]) {
self = .platforms(.init(platforms: platforms))
}
public init(configuration: BuildConfiguration) {
self = .configuration(.init(configuration: configuration))
}
}
/// Platforms condition implies that an assignment is valid on these platforms.
public struct PlatformsCondition: Hashable, Sendable {
public let platforms: [Platform]
public init(platforms: [Platform]) {
assert(!platforms.isEmpty, "List of platforms should not be empty")
self.platforms = platforms
}
public func satisfies(_ environment: BuildEnvironment) -> Bool {
platforms.contains(environment.platform)
}
}
/// A configuration condition implies that an assignment is valid on
/// a particular build configuration.
public struct ConfigurationCondition: Hashable, Sendable {
public let configuration: BuildConfiguration
public init(configuration: BuildConfiguration) {
self.configuration = configuration
}
public func satisfies(_ environment: BuildEnvironment) -> Bool {
if environment.configuration == nil {
return true
} else {
return configuration == environment.configuration
}
}
}
|