Skip to content

Commit 0895235

Browse files
authored
Merge pull request #29369 from nkcsgexi/collecting-linker-failed-abort
IRGen: don't proceed to IRGen if collecting linker directives failed
2 parents 8e09cd2 + 366e24e commit 0895235

File tree

2 files changed

+25
-0
lines changed

2 files changed

+25
-0
lines changed

lib/FrontendTool/FrontendTool.cpp

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1609,6 +1609,9 @@ static bool performCompileStepsPostSILGen(
16091609

16101610
llvm::StringSet<> LinkerDirectives;
16111611
collectLinkerDirectives(Invocation, MSF, LinkerDirectives);
1612+
// Don't proceed to IRGen if collecting linker directives failed.
1613+
if (Context.hadError())
1614+
return true;
16121615
StringRef OutputFilename = PSPs.OutputFilename;
16131616
std::vector<std::string> ParallelOutputFilenames =
16141617
Invocation.getFrontendOptions().InputsAndOutputs.copyOutputFilenames();
Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
// REQUIRES: OS=macosx
2+
// RUN: %empty-directory(%t)
3+
// RUN: echo '[ { "module": "OriginalModule", "platforms": ["macOS"], "install_name": "/System/OriginalModule.dylib"} ]' > %t/install-name.json
4+
// RUN: %target-swift-frontend -swift-version 4 -enforce-exclusivity=checked %s -emit-ir -module-name CurrentModule -D CURRENT_MODULE -previous-module-installname-map-file %t/install-name.json | %FileCheck %s -check-prefix=CHECK-SYMBOLS
5+
6+
// RUN: NOT %target-swift-frontend -swift-version 4 -enforce-exclusivity=checked %s -emit-ir -module-name CurrentModule -D CURRENT_MODULE -previous-module-installname-map-file %t/nil.json >& %t/error.txt
7+
// RUN: %FileCheck %s -check-prefix=CHECK-ERROR < %t/error.txt
8+
9+
@available(OSX 10.8, *)
10+
@_originallyDefinedIn(module: "OriginalModule", macOS 10.10)
11+
public struct Entity {
12+
public func addEntity(_ e: Entity) {}
13+
public func removeEntity(_ e: Entity) {}
14+
}
15+
16+
// CHECK-SYMBOLS: $ld$previous$/System/OriginalModule.dylib$$1$10.8$10.10$_$s14OriginalModule6EntityVMn$
17+
// CHECK-SYMBOLS: $ld$previous$/System/OriginalModule.dylib$$1$10.8$10.10$_$s14OriginalModule6EntityV03addC0yyACF$
18+
// CHECK-SYMBOLS: $ld$previous$/System/OriginalModule.dylib$$1$10.8$10.10$_$s14OriginalModule6EntityVN$
19+
// CHECK-SYMBOLS: $ld$previous$/System/OriginalModule.dylib$$1$10.8$10.10$_$s14OriginalModule6EntityVMa$
20+
// CHECK-SYMBOLS: $ld$previous$/System/OriginalModule.dylib$$1$10.8$10.10$_$s14OriginalModule6EntityV06removeC0yyACF$
21+
22+
// CHECK-ERROR: cannot open previous install name map

0 commit comments

Comments
 (0)