File: removed-decls.swift

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (104 lines) | stat: -rw-r--r-- 3,136 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
// REQUIRES: objc_interop

// RUN: %empty-directory(%t)
// RUN: mkdir -p %t/swiftmods %t/objcmods %t/objc
// RUN: %{python} %utils/split_file.py -o %t %s



// Create a module A, then B that depends on A, replace A with an empty module,
// and then try make a C that depends on B

// RUN: %target-swift-frontend -module-name A -emit-module -o %t/swiftmods/A.swiftmodule %t/a.swift
// RUN: %target-swift-frontend -module-name B -emit-module -o %t/swiftmods/B.swiftmodule -I %t/swiftmods %t/b.swift
// RUN: %target-swift-frontend -module-name A -emit-module -o %t/swiftmods/A.swiftmodule %t/bada.swift
// RUN: %target-swift-frontend -wmo -module-name C -emit-module -o %t/swiftmods/C.swiftmodule -I %t/swiftmods -experimental-allow-module-with-compiler-errors -index-store-path %t/idx %t/c.swift
// RUN: not --crash %target-swift-frontend -module-name C -emit-module -o %t/swiftmods/C.swiftmodule -I %t/swiftmods %t/c.swift

// Now do a similar thing but just use different headers instead (ie. to test
// loading from a PCM rather than swiftmodule)

// RUN: %target-swift-frontend(mock-sdk: %clang-importer-sdk) -module-name B -emit-module -o %t/objcmods/B.swiftmodule -I %t/objc -module-cache-path %t/mcp %t/b.swift
// RUN: mv %t/objc/bada.h %t/objc/a.h
// RUN: %target-swift-frontend(mock-sdk: %clang-importer-sdk) -module-name C -emit-module -o %t/objcmods/C.swiftmodule -I %t/objcmods -I %t/objc -module-cache-path %t/mcp -experimental-allow-module-with-compiler-errors -index-store-path %t/idx %t/c.swift
// RUN: not --crash %target-swift-frontend(mock-sdk: %clang-importer-sdk) -module-name C -emit-module -o %t/objcmods/C.swiftmodule -I %t/objcmods -I %t/objc -module-cache-path %t/mcp %t/c.swift

// BEGIN a.swift
public protocol ProtoA {}
public protocol MissingProto {}
open class MissingClass: ProtoA {}

// BEGIN bada.swift
public protocol ProtoA {}

// BEGIN objc/a.h
@import Foundation;
@protocol ProtoA
@end
@protocol MissingProto
@end
@interface MissingClass <ProtoA>
@end

// BEGIN objc/bada.h
@import Foundation;
@protocol ProtoA
@end

// BEGIN objc/module.modulemap
module A {
  header "a.h"
}

// BEGIN b.swift
import A

public protocol ProtoB: MissingProto {}
open class ClassB: MissingProto {}
open class InheritingClassB: MissingClass {}

public protocol ATProto {
  associatedtype Value
}
public protocol ReqProto: ATProto {
  static func thing(_ value: Value)
}
extension ReqProto where Value: ProtoA {
  public static func thing(_ value: Value) {}
}
public enum EnumB: ReqProto  {
  public typealias Value = MissingClass
  case a
}

// BEGIN c.swift
import B

func useB(p: ProtoB, c: ClassB, i: InheritingClassB, e: EnumB) {
  print("p:\(p) c:\(c) i:\(i) e:\(e)")
  EnumB.thing(i)
}

public protocol ProtoC: ProtoB {}
public class ClassC: ClassB {}
public class ClassC2: InheritingClassB {}

public struct AllAsMembers {
  let p: ProtoB
  let c: ClassB
  let i: InheritingClassB
  let e: EnumB
}

extension ProtoB {
  func newProtoBMethod() {}
}
extension ClassB {
  func newClassBMethod() {}
}
extension InheritingClassB {
  func newInheritingClassBMethod() {}
}
extension EnumB {
  func newEnumBMethod() {}
}