mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
[ModuleInterface] Short-circuit module loading for frameworks too (#24459)
Follow-up to 7969705 that handles frameworks as well. Oops.
rdar://problem/50070463
This commit is contained in:
@@ -264,24 +264,24 @@ SerializedModuleLoaderBase::findModule(AccessPathElem moduleID,
|
|||||||
moduleFramework += ".framework";
|
moduleFramework += ".framework";
|
||||||
isFramework = true;
|
isFramework = true;
|
||||||
|
|
||||||
auto tryFrameworkImport = [&](StringRef frameworkPath) -> bool {
|
auto tryFrameworkImport = [&](StringRef frameworkPath) -> Optional<bool> {
|
||||||
currPath = frameworkPath;
|
currPath = frameworkPath;
|
||||||
llvm::sys::path::append(currPath, moduleFramework.str());
|
llvm::sys::path::append(currPath, moduleFramework.str());
|
||||||
|
|
||||||
// Check if the framework directory exists
|
// Check if the framework directory exists
|
||||||
if (!fs.exists(currPath)) {
|
if (!fs.exists(currPath)) {
|
||||||
return false;
|
return None;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Frameworks always use architecture-specific files within a .swiftmodule
|
// Frameworks always use architecture-specific files within a .swiftmodule
|
||||||
// directory.
|
// directory.
|
||||||
llvm::sys::path::append(currPath, "Modules", fileNames.module.str());
|
llvm::sys::path::append(currPath, "Modules", fileNames.module.str());
|
||||||
return findTargetSpecificModuleFiles().getValueOr(false);
|
return findTargetSpecificModuleFiles();
|
||||||
};
|
};
|
||||||
|
|
||||||
for (const auto &framepath : Ctx.SearchPathOpts.FrameworkSearchPaths) {
|
for (const auto &framepath : Ctx.SearchPathOpts.FrameworkSearchPaths) {
|
||||||
if (tryFrameworkImport(framepath.Path))
|
if (auto outcome = tryFrameworkImport(framepath.Path))
|
||||||
return true;
|
return outcome.getValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Ctx.LangOpts.Target.isOSDarwin()) {
|
if (Ctx.LangOpts.Target.isOSDarwin()) {
|
||||||
@@ -290,13 +290,13 @@ SerializedModuleLoaderBase::findModule(AccessPathElem moduleID,
|
|||||||
SmallString<256> scratch;
|
SmallString<256> scratch;
|
||||||
scratch = Ctx.SearchPathOpts.SDKPath;
|
scratch = Ctx.SearchPathOpts.SDKPath;
|
||||||
llvm::sys::path::append(scratch, "System", "Library", "Frameworks");
|
llvm::sys::path::append(scratch, "System", "Library", "Frameworks");
|
||||||
if (tryFrameworkImport(scratch))
|
if (auto outcome = tryFrameworkImport(scratch))
|
||||||
return true;
|
return outcome.getValue();
|
||||||
|
|
||||||
scratch = Ctx.SearchPathOpts.SDKPath;
|
scratch = Ctx.SearchPathOpts.SDKPath;
|
||||||
llvm::sys::path::append(scratch, "Library", "Frameworks");
|
llvm::sys::path::append(scratch, "Library", "Frameworks");
|
||||||
if (tryFrameworkImport(scratch))
|
if (auto outcome = tryFrameworkImport(scratch))
|
||||||
return true;
|
return outcome.getValue();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,31 @@
|
|||||||
|
// RUN: %empty-directory(%t/BuildDir/Lib.framework/Modules/Lib.swiftmodule)
|
||||||
|
// RUN: %empty-directory(%t/SecondBuildDir/Lib.framework/Modules/Lib.swiftmodule)
|
||||||
|
// RUN: %empty-directory(%t/ModuleCache)
|
||||||
|
|
||||||
|
// RUN: echo 'public func showsUpInBothPlaces() {}' > %t/Lib.swift
|
||||||
|
|
||||||
|
// 1. Create a .swiftinterface file containing just one API, and put it inside a second build dir (without a .swiftmodule)
|
||||||
|
// RUN: %target-swift-frontend -typecheck %t/Lib.swift -emit-parseable-module-interface-path %t/SecondBuildDir/Lib.framework/Modules/Lib.swiftmodule/%target-cpu.swiftinterface -module-name Lib
|
||||||
|
|
||||||
|
// 2. Add a new API to the module, and compile just the serialized version in the build dir.
|
||||||
|
// RUN: echo 'public func onlyInTheCompiledModule() {}' >> %t/Lib.swift
|
||||||
|
// RUN: %target-swift-frontend -emit-module %t/Lib.swift -o %t/BuildDir/Lib.framework/Modules/Lib.swiftmodule/%target-cpu.swiftmodule -emit-parseable-module-interface-path %t/BuildDir/Lib.framework/Modules/Lib.swiftmodule/%target-cpu.swiftinterface -module-name Lib
|
||||||
|
|
||||||
|
// 3. Make sure when we compile this test file, we can access both APIs since we'll
|
||||||
|
// load the compiled .swiftmodule instead of the .swiftinterface in the SDK.
|
||||||
|
// RUN: %target-swift-frontend -typecheck %s -F %t/BuildDir -F %t/SecondBuildDir -module-cache-path %t/ModuleCache
|
||||||
|
|
||||||
|
// 4. Make sure we didn't compile any .swiftinterfaces into the module cache.
|
||||||
|
// RUN: ls %t/ModuleCache | not grep 'swiftmodule'
|
||||||
|
|
||||||
|
// 5. This should also work if the swiftinterface isn't present in the first build dir.
|
||||||
|
// RUN: rm %t/BuildDir/Lib.framework/Modules/Lib.swiftmodule/%target-cpu.swiftinterface
|
||||||
|
// RUN: %target-swift-frontend -typecheck %s -F %t/BuildDir -F %t/SecondBuildDir -module-cache-path %t/ModuleCache
|
||||||
|
|
||||||
|
// 6. Make sure we /still/ didn't compile any .swiftinterfaces into the module cache.
|
||||||
|
// RUN: ls %t/ModuleCache | not grep 'swiftmodule'
|
||||||
|
|
||||||
|
import Lib
|
||||||
|
|
||||||
|
showsUpInBothPlaces()
|
||||||
|
onlyInTheCompiledModule()
|
||||||
@@ -5,7 +5,7 @@
|
|||||||
// RUN: echo 'public func showsUpInBothPlaces() {}' > %t/Lib.swift
|
// RUN: echo 'public func showsUpInBothPlaces() {}' > %t/Lib.swift
|
||||||
|
|
||||||
// 1. Create a .swiftinterface file containing just one API, and put it inside a second build dir (without a .swiftmodule)
|
// 1. Create a .swiftinterface file containing just one API, and put it inside a second build dir (without a .swiftmodule)
|
||||||
// RUN: %target-swift-frontend -typecheck %t/Lib.swift -emit-parseable-module-interface-path %t/SecondBuildDir/Lib.swiftmodule/%target-cpu.swiftinterface
|
// RUN: %target-swift-frontend -typecheck %t/Lib.swift -emit-parseable-module-interface-path %t/SecondBuildDir/Lib.swiftmodule/%target-cpu.swiftinterface -module-name Lib
|
||||||
|
|
||||||
// 2. Add a new API to the module, and compile just the serialized version in the build dir.
|
// 2. Add a new API to the module, and compile just the serialized version in the build dir.
|
||||||
// RUN: echo 'public func onlyInTheCompiledModule() {}' >> %t/Lib.swift
|
// RUN: echo 'public func onlyInTheCompiledModule() {}' >> %t/Lib.swift
|
||||||
@@ -18,7 +18,14 @@
|
|||||||
// 4. Make sure we didn't compile any .swiftinterfaces into the module cache.
|
// 4. Make sure we didn't compile any .swiftinterfaces into the module cache.
|
||||||
// RUN: ls %t/ModuleCache | not grep 'swiftmodule'
|
// RUN: ls %t/ModuleCache | not grep 'swiftmodule'
|
||||||
|
|
||||||
|
// 5. This should also work if the swiftinterface isn't present in the first build dir.
|
||||||
|
// RUN: rm %t/BuildDir/Lib.swiftinterface
|
||||||
|
// RUN: %target-swift-frontend -typecheck %s -I %t/BuildDir -I %t/SecondBuildDir -module-cache-path %t/ModuleCache
|
||||||
|
|
||||||
|
// 6. Make sure we /still/ didn't compile any .swiftinterfaces into the module cache.
|
||||||
|
// RUN: ls %t/ModuleCache | not grep 'swiftmodule'
|
||||||
|
|
||||||
import Lib
|
import Lib
|
||||||
|
|
||||||
showsUpInBothPlaces()
|
showsUpInBothPlaces()
|
||||||
onlyInTheCompiledModule()
|
onlyInTheCompiledModule()
|
||||||
|
|||||||
Reference in New Issue
Block a user