mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
Instead of replacing an interface file with its up-to-date compile module, the dep-scanner should report potentially up-to-date module candidates either adjacent to the interface file or in the prebuilt module cache. swift-driver should later pass down these candidates to -compile-module-from-interface invocation and the front-end job will check if one of the candidates is ready to use. The front-end job then either emits a forwarding module to an up-to-date candidate or a binary module.
162 lines
4.7 KiB
Swift
162 lines
4.7 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 paths of potentially ready-to-use compiled modules for the interface.
|
|
var compiledModuleCandidates: [String]?
|
|
|
|
/// The compiled Swift module to use.
|
|
var compiledModulePath: 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)]! }
|
|
}
|