Files
swift-mirror/include/swift/Serialization/ScanningLoaders.h
Artem Chikin 9f0083c7c0 [Dependency Scanning] Refactor Clang dependency bridging into a 'ModuleDependencyScanner' utility
This moves the functionality of 'bridgeClangModuleDependency' into a utility in the main scanner class because it relies on various objects whose lifetime is already tied to the scanner itself.
2025-08-15 15:40:41 -07:00

112 lines
4.5 KiB
C++

//===--- ScanningLoaders.h - Swift module scanning --------------*- C++ -*-===//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2023 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
//
//===----------------------------------------------------------------------===//
#ifndef SWIFT_SCANNINGLOADERS_H
#define SWIFT_SCANNINGLOADERS_H
#include "swift/AST/ASTContext.h"
#include "swift/AST/ModuleDependencies.h"
#include "swift/Frontend/ModuleInterfaceLoader.h"
#include "swift/Serialization/SerializedModuleLoader.h"
namespace swift {
/// Result of looking up a Swift module on the current filesystem
/// search paths.
struct SwiftModuleScannerQueryResult {
struct IncompatibleCandidate {
std::string path;
std::string incompatibilityReason;
};
SwiftModuleScannerQueryResult()
: foundDependencyInfo(std::nullopt), incompatibleCandidates() {}
SwiftModuleScannerQueryResult(
std::optional<ModuleDependencyInfo> &&dependencyInfo,
std::vector<IncompatibleCandidate> &&candidates)
: foundDependencyInfo(dependencyInfo),
incompatibleCandidates(candidates) {}
std::optional<ModuleDependencyInfo> foundDependencyInfo;
std::vector<IncompatibleCandidate> incompatibleCandidates;
};
/// A module "loader" that looks for .swiftinterface and .swiftmodule files
/// for the purpose of determining dependencies, but does not attempt to
/// load the module files.
class SwiftModuleScanner : public SerializedModuleLoaderBase {
private:
/// Scan the given interface file to determine dependencies.
llvm::ErrorOr<ModuleDependencyInfo>
scanInterfaceFile(Identifier moduleID, Twine moduleInterfacePath,
bool isFramework, bool isTestableImport);
/// Scan the given serialized module file to determine dependencies.
llvm::ErrorOr<ModuleDependencyInfo>
scanBinaryModuleFile(Identifier moduleID, Twine binaryModulePath,
bool isFramework, bool isTestableImport,
bool isCandidateForTextualModule);
std::error_code findModuleFilesInDirectory(
ImportPath::Element ModuleID, const SerializedModuleBaseName &BaseName,
SmallVectorImpl<char> *ModuleInterfacePath,
SmallVectorImpl<char> *ModuleInterfaceSourcePath,
std::unique_ptr<llvm::MemoryBuffer> *ModuleBuffer,
std::unique_ptr<llvm::MemoryBuffer> *ModuleDocBuffer,
std::unique_ptr<llvm::MemoryBuffer> *ModuleSourceInfoBuffer,
bool SkipBuildingInterface, bool IsFramework,
bool IsTestableDependencyLookup) override;
bool canImportModule(ImportPath::Module named, SourceLoc loc,
ModuleVersionInfo *versionInfo,
bool isTestableImport) override;
virtual void collectVisibleTopLevelModuleNames(
SmallVectorImpl<Identifier> &names) const override {
llvm_unreachable("Not used");
}
/// AST delegate to be used for textual interface scanning
InterfaceSubContextDelegate &astDelegate;
/// Clang-specific (-Xcc) command-line flags to include on
/// Swift module compilation commands
std::vector<std::string> swiftModuleClangCC1CommandLineArgs;
/// Module inputs specified with -swift-module-input,
/// <ModuleName, Path to .swiftmodule file>
llvm::StringMap<std::string> explicitSwiftModuleInputs;
/// Constituents of a result of a given Swift module query,
/// reset at the end of every query.
std::optional<ModuleDependencyInfo> foundDependencyInfo;
std::vector<SwiftModuleScannerQueryResult::IncompatibleCandidate>
incompatibleCandidates;
public:
SwiftModuleScanner(
ASTContext &ctx, ModuleLoadingMode LoadMode,
InterfaceSubContextDelegate &astDelegate,
std::vector<std::string> swiftModuleClangCC1CommandLineArgs,
llvm::StringMap<std::string> &explicitSwiftModuleInputs)
: SerializedModuleLoaderBase(ctx, nullptr, LoadMode,
/*IgnoreSwiftSourceInfoFile=*/true),
astDelegate(astDelegate),
swiftModuleClangCC1CommandLineArgs(swiftModuleClangCC1CommandLineArgs),
explicitSwiftModuleInputs(explicitSwiftModuleInputs) {
}
/// Perform a filesystem search for a Swift module with a given name
SwiftModuleScannerQueryResult lookupSwiftModule(Identifier moduleName,
bool isTestableImport);
};
} // namespace swift
#endif // SWIFT_SCANNINGLOADERS_H