mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
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.
66 lines
1.7 KiB
Swift
66 lines
1.7 KiB
Swift
//===--- SourceLoc.swift - SourceLoc bridging utilities ------------------===//
|
|
//
|
|
// This source file is part of the Swift.org open source project
|
|
//
|
|
// Copyright (c) 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 ASTBridging
|
|
|
|
public struct SourceLoc {
|
|
/// Points into a source file.
|
|
let locationInFile: UnsafePointer<UInt8>
|
|
|
|
public init?(locationInFile: UnsafePointer<UInt8>?) {
|
|
guard let locationInFile = locationInFile else {
|
|
return nil
|
|
}
|
|
self.locationInFile = locationInFile
|
|
}
|
|
|
|
public init?(bridged: BridgedSourceLoc) {
|
|
guard bridged.isValid() else {
|
|
return nil
|
|
}
|
|
self.locationInFile = bridged.opaquePointer!
|
|
}
|
|
|
|
public var bridged: BridgedSourceLoc {
|
|
.init(opaquePointer: locationInFile)
|
|
}
|
|
}
|
|
|
|
extension SourceLoc {
|
|
public func advanced(by n: Int) -> SourceLoc {
|
|
SourceLoc(locationInFile: locationInFile.advanced(by: n))!
|
|
}
|
|
}
|
|
|
|
extension Optional where Wrapped == SourceLoc {
|
|
public var bridged: BridgedSourceLoc {
|
|
self?.bridged ?? .init()
|
|
}
|
|
}
|
|
|
|
public struct CharSourceRange {
|
|
public let start: SourceLoc
|
|
public let byteLength: UInt32
|
|
|
|
public init(start: SourceLoc, byteLength: UInt32) {
|
|
self.start = start
|
|
self.byteLength = byteLength
|
|
}
|
|
|
|
public init?(bridgedStart: BridgedSourceLoc, byteLength: UInt32) {
|
|
guard let start = SourceLoc(bridged: bridgedStart) else {
|
|
return nil
|
|
}
|
|
self.init(start: start, byteLength: byteLength)
|
|
}
|
|
}
|