mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Trying to use members of C++ private base classes from Swift causes an assertion failure in ClangImporter:
```
<build dir>/swift/lib/swift/macosx/arm64/libcxxshim.h:2:66: error: cannot cast 'A' to its private base class 'B'
To __swift_interopStaticCast(From from) { return static_cast<To>(from); }
^
```
Such members should not be exposed.
rdar://103871000
103 lines
4.5 KiB
Swift
103 lines
4.5 KiB
Swift
// RUN: %target-swift-ide-test -print-module -print-implicit-attrs -module-to-print=Functions -I %S/Inputs -source-filename=x -enable-experimental-cxx-interop | %FileCheck %s
|
|
|
|
// CHECK: struct NonTrivial {
|
|
// CHECK-NEXT: init()
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func inNonTrivial() -> UnsafePointer<CChar>!
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func inNonTrivialWithArgs(_ a: Int32, _ b: Int32) -> UnsafePointer<CChar>!
|
|
// CHECK-NEXT: }
|
|
|
|
// CHECK-NEXT: struct Base {
|
|
// CHECK-NEXT: init()
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: mutating func mutatingInBase() -> UnsafePointer<CChar>!
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func constInBase() -> UnsafePointer<CChar>!
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func takesArgsInBase(_ a: Int32, _ b: Int32, _ c: Int32) -> UnsafePointer<CChar>!
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func takesNonTrivialInBase(_ a: NonTrivial) -> UnsafePointer<CChar>!
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func returnsNonTrivialInBase() -> NonTrivial
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func templateInBase<T>(_ t: T) -> UnsafePointer<CChar>!
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: static func staticInBase() -> UnsafePointer<CChar>!
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: mutating func swiftRenamed(input i: Int32) -> Int32
|
|
// CHECK-NEXT: @available(swift, obsoleted: 3, renamed: "swiftRenamed(input:)")
|
|
// CHECK-NEXT: mutating func renamed(_ i: Int32) -> Int32
|
|
// CHECK-NEXT: @_effects(readonly) func pure()
|
|
// CHECK-NEXT: }
|
|
|
|
// CHECK-NEXT: struct OtherBase {
|
|
// CHECK-NEXT: init()
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func inOtherBase() -> UnsafePointer<CChar>!
|
|
// CHECK-NEXT: }
|
|
|
|
// CHECK-NEXT: struct Derived {
|
|
// CHECK-NEXT: init()
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func inDerived() -> UnsafePointer<CChar>!
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: mutating func mutatingInBase() -> UnsafePointer<CChar>?
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func constInBase() -> UnsafePointer<CChar>?
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func takesArgsInBase(_ a: Int32, _ b: Int32, _ c: Int32) -> UnsafePointer<CChar>?
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func takesNonTrivialInBase(_ a: NonTrivial) -> UnsafePointer<CChar>?
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func returnsNonTrivialInBase() -> NonTrivial
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: mutating func swiftRenamed(input i: Int32) -> Int32
|
|
// CHECK-NEXT: @available(swift, obsoleted: 3, renamed: "swiftRenamed(input:)")
|
|
// CHECK-NEXT: mutating func renamed(_ i: Int32) -> Int32
|
|
// CHECK-NEXT: @_effects(readonly) func pure()
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func inOtherBase() -> UnsafePointer<CChar>?
|
|
// CHECK-NEXT: }
|
|
|
|
// CHECK-NEXT: struct DerivedFromDerived {
|
|
// CHECK-NEXT: init()
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func topLevel() -> UnsafePointer<CChar>!
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func inDerived() -> UnsafePointer<CChar>?
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: mutating func mutatingInBase() -> UnsafePointer<CChar>?
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func constInBase() -> UnsafePointer<CChar>?
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func takesArgsInBase(_ a: Int32, _ b: Int32, _ c: Int32) -> UnsafePointer<CChar>?
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func takesNonTrivialInBase(_ a: NonTrivial) -> UnsafePointer<CChar>?
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func returnsNonTrivialInBase() -> NonTrivial
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: mutating func swiftRenamed(input i: Int32) -> Int32
|
|
// CHECK-NEXT: @available(swift, obsoleted: 3, renamed: "swiftRenamed(input:)")
|
|
// CHECK-NEXT: mutating func renamed(_ i: Int32) -> Int32
|
|
// CHECK-NEXT: @_effects(readonly) func pure()
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func inOtherBase() -> UnsafePointer<CChar>?
|
|
// CHECK-NEXT: }
|
|
|
|
// CHECK-NEXT: struct DerivedFromNonTrivial {
|
|
// CHECK-NEXT: init()
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func inNonTrivial() -> UnsafePointer<CChar>?
|
|
// CHECK-NEXT: @discardableResult
|
|
// CHECK-NEXT: func inNonTrivialWithArgs(_ a: Int32, _ b: Int32) -> UnsafePointer<CChar>?
|
|
// CHECK-NEXT: }
|
|
|
|
// CHECK-NEXT: struct PrivatelyInherited {
|
|
// CHECK-NEXT: init()
|
|
// CHECK-NEXT: }
|
|
|
|
// CHECK-NEXT: struct ProtectedInherited {
|
|
// CHECK-NEXT: init()
|
|
// CHECK-NEXT: }
|