Files
swift-mirror/SwiftCompilerSources/Sources/AST/SubstitutionMap.swift
2025-06-08 11:22:45 +03:00

81 lines
2.7 KiB
Swift

//===--- SubstitutionMap.swift --------------------------------------------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2024 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
import Basic
import ASTBridging
/// SubstitutionMap describes the mapping of abstract types to replacement types,
/// together with associated conformances to use for deriving nested types and conformances.
///
/// Substitution maps are primarily used when performing substitutions into any entity that
/// can reference type parameters and conformances.
public struct SubstitutionMap: CustomStringConvertible, NoReflectionChildren {
public let bridged: BridgedSubstitutionMap
public init(bridged: BridgedSubstitutionMap) {
self.bridged = bridged
}
public init() {
self.bridged = BridgedSubstitutionMap()
}
public init(genericSignature: GenericSignature, replacementTypes: [Type]) {
let bridgedReplTypes = replacementTypes.map { $0.bridged }
self.bridged = bridgedReplTypes.withBridgedArrayRef {
return BridgedSubstitutionMap.get(genericSignature.bridged, $0)
}
}
public var description: String {
return String(taking: bridged.getDebugDescription())
}
public var isEmpty: Bool { bridged.isEmpty() }
public var hasAnySubstitutableParams: Bool { bridged.hasAnySubstitutableParams() }
public var conformances: ConformanceArray { ConformanceArray(substitutionMap: self) }
public struct ConformanceArray : BridgedRandomAccessCollection {
fileprivate let bridgedSubs: BridgedSubstitutionMap
public let count: Int
init(substitutionMap: SubstitutionMap) {
self.bridgedSubs = substitutionMap.bridged
self.count = substitutionMap.bridged.getNumConformances()
}
public var startIndex: Int { return 0 }
public var endIndex: Int { return count }
public subscript(_ index: Int) -> Conformance {
assert(index >= startIndex && index < endIndex)
return Conformance(bridged: bridgedSubs.getConformance(index))
}
}
public var replacementTypes: TypeArray {
TypeArray(bridged: bridged.getReplacementTypes())
}
/// The single replacement type if it's guaranteed that the substitution map has a single replacement type.
public var replacementType: Type {
assert(replacementTypes.count == 1)
return replacementTypes[0]
}
public static func ==(lhs: SubstitutionMap, rhs: SubstitutionMap) -> Bool {
lhs.bridged.isEqualTo(rhs.bridged)
}
}