mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
Building each Swift module explicitly requires dependency PCMs to be built with the exactly same deployment target version. This means we may need to build a Clang module multiple times with different target triples. This patch removes the -target arguments from the reported PCM build arguments and inserts extraPcmArgs fields to each Swift module. swift-driver can combine the generic PCM arguments with these extra arguments to get the command suitable for building a PCM specifically for that loading Swift module.
156 lines
4.5 KiB
Swift
156 lines
4.5 KiB
Swift
//===--------------- ModuleDependencyGraph.swift --------------------------===//
|
|
//
|
|
// This source file is part of the Swift.org open source project
|
|
//
|
|
// Copyright (c) 2014 - 2019 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 Foundation
|
|
|
|
enum ModuleDependencyId: Hashable {
|
|
case swift(String)
|
|
case clang(String)
|
|
|
|
var moduleName: String {
|
|
switch self {
|
|
case .swift(let name): return name
|
|
case .clang(let name): return name
|
|
}
|
|
}
|
|
}
|
|
|
|
extension ModuleDependencyId: Codable {
|
|
enum CodingKeys: CodingKey {
|
|
case swift
|
|
case clang
|
|
}
|
|
|
|
init(from decoder: Decoder) throws {
|
|
let container = try decoder.container(keyedBy: CodingKeys.self)
|
|
do {
|
|
let moduleName = try container.decode(String.self, forKey: .swift)
|
|
self = .swift(moduleName)
|
|
} catch {
|
|
let moduleName = try container.decode(String.self, forKey: .clang)
|
|
self = .clang(moduleName)
|
|
}
|
|
}
|
|
|
|
func encode(to encoder: Encoder) throws {
|
|
var container = encoder.container(keyedBy: CodingKeys.self)
|
|
switch self {
|
|
case .swift(let moduleName):
|
|
try container.encode(moduleName, forKey: .swift)
|
|
case .clang(let moduleName):
|
|
try container.encode(moduleName, forKey: .clang)
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Bridging header
|
|
struct BridgingHeader: Codable {
|
|
var path: String
|
|
var sourceFiles: [String]
|
|
var moduleDependencies: [String]
|
|
}
|
|
|
|
/// Details specific to Swift modules.
|
|
struct SwiftModuleDetails: Codable {
|
|
/// The module interface from which this module was built, if any.
|
|
var moduleInterfacePath: String?
|
|
|
|
/// The bridging header, if any.
|
|
var bridgingHeader: BridgingHeader?
|
|
|
|
/// The Swift command line arguments that need to be passed through
|
|
/// to the -compile-module-from-interface action to build this module.
|
|
var commandLine: [String]?
|
|
|
|
/// To build a PCM to be used by this Swift module, we need to append these
|
|
/// arguments to the generic PCM build arguments reported from the dependency
|
|
/// graph.
|
|
var extraPcmArgs: [String]?
|
|
}
|
|
|
|
/// Details specific to Clang modules.
|
|
struct ClangModuleDetails: Codable {
|
|
/// The path to the module map used to build this module.
|
|
var moduleMapPath: String
|
|
|
|
/// The context hash used to discriminate this module file.
|
|
var contextHash: String
|
|
|
|
/// The Clang command line arguments that need to be passed through
|
|
/// to the -emit-pcm action to build this module.
|
|
var commandLine: [String] = []
|
|
}
|
|
|
|
struct ModuleDependencies: Codable {
|
|
/// The path for the module.
|
|
var modulePath: String
|
|
|
|
/// The source files used to build this module.
|
|
var sourceFiles: [String] = []
|
|
|
|
/// The set of direct module dependencies of this module.
|
|
var directDependencies: [ModuleDependencyId] = []
|
|
|
|
/// Specific details of a particular kind of module.
|
|
var details: Details
|
|
|
|
/// Specific details of a particular kind of module.
|
|
enum Details {
|
|
/// Swift modules may be built from a module interface, and may have
|
|
/// a bridging header.
|
|
case swift(SwiftModuleDetails)
|
|
|
|
/// Clang modules are built from a module map file.
|
|
case clang(ClangModuleDetails)
|
|
}
|
|
}
|
|
|
|
extension ModuleDependencies.Details: Codable {
|
|
enum CodingKeys: CodingKey {
|
|
case swift
|
|
case clang
|
|
}
|
|
|
|
init(from decoder: Decoder) throws {
|
|
let container = try decoder.container(keyedBy: CodingKeys.self)
|
|
do {
|
|
let details = try container.decode(SwiftModuleDetails.self, forKey: .swift)
|
|
self = .swift(details)
|
|
} catch {
|
|
let details = try container.decode(ClangModuleDetails.self, forKey: .clang)
|
|
self = .clang(details)
|
|
}
|
|
}
|
|
|
|
func encode(to encoder: Encoder) throws {
|
|
var container = encoder.container(keyedBy: CodingKeys.self)
|
|
switch self {
|
|
case .swift(let details):
|
|
try container.encode(details, forKey: .swift)
|
|
case .clang(let details):
|
|
try container.encode(details, forKey: .clang)
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Describes the complete set of dependencies for a Swift module, including
|
|
/// all of the Swift and C modules and source files it depends on.
|
|
struct ModuleDependencyGraph: Codable {
|
|
/// The name of the main module.
|
|
var mainModuleName: String
|
|
|
|
/// The complete set of modules discovered
|
|
var modules: [ModuleDependencyId: ModuleDependencies] = [:]
|
|
|
|
/// Information about the main module.
|
|
var mainModule: ModuleDependencies { modules[.swift(mainModuleName)]! }
|
|
}
|