Skip to content

Commit 3a9161c

Browse files
authored
Merge pull request #75352 from tshortli/inlined-zippered-availability-6.0
[6.0] ModuleInterface: Print -target-variant flag in .swiftinterface files
2 parents 4305bf6 + 43f49d5 commit 3a9161c

File tree

3 files changed

+53
-1
lines changed

3 files changed

+53
-1
lines changed

include/swift/Option/Options.td

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1353,7 +1353,7 @@ def target_cpu : Separate<["-"], "target-cpu">, Flags<[FrontendOption, ModuleInt
13531353
HelpText<"Generate code for a particular CPU variant">;
13541354

13551355
def target_variant : Separate<["-"], "target-variant">,
1356-
Flags<[FrontendOption]>,
1356+
Flags<[FrontendOption, ModuleInterfaceOption]>,
13571357
HelpText<"Generate 'zippered' code for macCatalyst that can run on the specified"
13581358
" variant target triple in addition to the main -target triple">;
13591359

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
// RUN: %empty-directory(%t)
2+
// RUN: %target-swift-emit-module-interface(%t/TargetVariant.swiftinterface) %s -module-name TargetVariant -target %target-cpu-apple-macosx13 -target-variant %target-cpu-apple-ios16-macabi
3+
// RUN: %target-swift-typecheck-module-from-interface(%t/TargetVariant.swiftinterface) -module-name TargetVariant
4+
// RUN: %FileCheck %s < %t/TargetVariant.swiftinterface
5+
6+
// REQUIRES: OS=macosx
7+
8+
// CHECK: swift-module-flags
9+
// CHECK-SAME: -target {{.*}}-apple-macosx13
10+
// CHECK-SAME: -target-variant {{.*}}-apple-ios16-macabi
11+
12+
// CHECK: public func test()
13+
public func test() {}
Lines changed: 39 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,39 @@
1+
// RUN: %empty-directory(%t)
2+
// RUN: split-file %s %t
3+
4+
// RUN: %target-swift-frontend -emit-module %t/Library.swift -swift-version 5 -enable-library-evolution -module-name Library -target %target-cpu-apple-macosx13 -target-variant %target-cpu-apple-ios16-macabi -o %t -emit-module-interface-path %t/Library.swiftinterface
5+
// RUN: %target-swift-frontend -emit-sil %t/main.swift -target %target-cpu-apple-macosx13 -target-variant %target-cpu-apple-ios16-macabi -I %t | %FileCheck %t/main.swift
6+
7+
// Remove the .swiftmodule and test again with the library module built from interface.
8+
9+
// RUN: rm %t/Library.swiftmodule
10+
// RUN: %target-swift-frontend -emit-sil %t/main.swift -target %target-cpu-apple-macosx13 -target-variant %target-cpu-apple-ios16-macabi -I %t | %FileCheck %t/main.swift
11+
12+
// REQUIRES: maccatalyst_support
13+
14+
//--- Library.swift
15+
16+
public func foo() {}
17+
18+
@_alwaysEmitIntoClient
19+
public func test() {
20+
if #available(macOS 14, iOS 17, *) {
21+
foo()
22+
}
23+
}
24+
25+
//--- main.swift
26+
27+
import Library
28+
29+
test()
30+
31+
// CHECK-LABEL: sil shared @$s7Library4testyyF
32+
// CHECK: [[MACOS_MAJOR:%.*]] = integer_literal $Builtin.Word, 14
33+
// CHECK: [[MACOS_MINOR:%.*]] = integer_literal $Builtin.Word, 0
34+
// CHECK: [[MACOS_PATCH:%.*]] = integer_literal $Builtin.Word, 0
35+
// CHECK: [[IOS_MAJOR:%.*]] = integer_literal $Builtin.Word, 17
36+
// CHECK: [[IOS_MINOR:%.*]] = integer_literal $Builtin.Word, 0
37+
// CHECK: [[IOS_PATCH:%.*]] = integer_literal $Builtin.Word, 0
38+
// CHECK: [[FUNC:%.*]] = function_ref @$ss042_stdlib_isOSVersionAtLeastOrVariantVersiondE0yBi1_Bw_BwBwBwBwBwtF : $@convention(thin) (Builtin.Word, Builtin.Word, Builtin.Word, Builtin.Word, Builtin.Word, Builtin.Word) -> Builtin.Int1
39+
// CHECK: [[QUERY_RESULT:%.*]] = apply [[FUNC]]([[MACOS_MAJOR]], [[MACOS_MINOR]], [[MACOS_PATCH]], [[IOS_MAJOR]], [[IOS_MINOR]], [[IOS_PATCH]]) : $@convention(thin) (Builtin.Word, Builtin.Word, Builtin.Word, Builtin.Word, Builtin.Word, Builtin.Word) -> Builtin.Int1

0 commit comments

Comments
 (0)