Files
swift-mirror/SwiftCompilerSources/Sources/SIL/WitnessTable.swift
Erik Eckstein 2dbd6cc56b SwiftCompilerSources: rework bridging
Introduce two modes of bridging:
* inline mode: this is basically how it worked so far. Using full C++ interop which allows bridging functions to be inlined.
* pure mode: bridging functions are not inlined but compiled in a cpp file. This allows to reduce the C++ interop requirements to a minimum. No std/llvm/swift headers are imported.

This change requires a major refactoring of bridging sources. The implementation of bridging functions go to two separate files: SILBridgingImpl.h and OptimizerBridgingImpl.h.
Depending on the mode, those files are either included in the corresponding header files (inline mode), or included in the c++ file (pure mode).

The mode can be selected with the BRIDGING_MODE cmake variable. By default it is set to the inline mode (= existing behavior). The pure mode is only selected in certain configurations to work around C++ interop issues:
* In debug builds, to workaround a problem with LLDB's `po` command (rdar://115770255).
* On windows to workaround a build problem.
2023-10-09 09:52:52 +02:00

97 lines
2.8 KiB
Swift

//===--- WitnessTable.swift -----------------------------------------------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2022 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 SILBridging
public struct WitnessTable : CustomStringConvertible, NoReflectionChildren {
public let bridged: BridgedWitnessTable
public init(bridged: BridgedWitnessTable) { self.bridged = bridged }
public struct Entry : CustomStringConvertible, NoReflectionChildren {
fileprivate let bridged: BridgedWitnessTableEntry
public typealias Kind = BridgedWitnessTableEntry.Kind
public var kind: Kind {
return bridged.getKind()
}
public var methodFunction: Function? {
assert(kind == .Method)
return bridged.getMethodFunction().function
}
public var description: String {
return String(taking: bridged.getDebugDescription())
}
}
public struct EntryArray : BridgedRandomAccessCollection {
fileprivate let base: BridgedWitnessTableEntry
public let count: Int
public var startIndex: Int { return 0 }
public var endIndex: Int { return count }
public subscript(_ index: Int) -> Entry {
assert(index >= startIndex && index < endIndex)
return Entry(bridged: base.advanceBy(index))
}
}
public var entries: EntryArray {
let entries = bridged.getEntries()
return EntryArray(base: entries.base, count: entries.count)
}
public var description: String {
return String(taking: bridged.getDebugDescription())
}
}
public struct DefaultWitnessTable : CustomStringConvertible, NoReflectionChildren {
public let bridged: BridgedDefaultWitnessTable
public init(bridged: BridgedDefaultWitnessTable) { self.bridged = bridged }
public typealias Entry = WitnessTable.Entry
public typealias EntryArray = WitnessTable.EntryArray
public var entries: EntryArray {
let entries = bridged.getEntries()
return EntryArray(base: entries.base, count: entries.count)
}
public var description: String {
return String(taking: bridged.getDebugDescription())
}
}
extension OptionalBridgedWitnessTable {
public var witnessTable: WitnessTable? {
if let table = table {
return WitnessTable(bridged: BridgedWitnessTable(table: table))
}
return nil
}
}
extension OptionalBridgedDefaultWitnessTable {
public var defaultWitnessTable: DefaultWitnessTable? {
if let table = table {
return DefaultWitnessTable(bridged: BridgedDefaultWitnessTable(table: table))
}
return nil
}
}