| 12
 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
 
 | // RUN: %target-run-simple-swift %s | %FileCheck %s
// REQUIRES: executable_test
// REQUIRES: objc_interop
import Foundation
// Category on a nested class
class OuterClass {
  class InnerClass: NSObject {}
}
extension OuterClass.InnerClass {
  @objc static let propertyInExtension = "foo"
  @objc func dynamicMethod() -> String {
    return "bar"
  }
}
let x = OuterClass.InnerClass()
// CHECK: foo
print(type(of: x).propertyInExtension)
// CHECK: bar
print(x.dynamicMethod())
// Category on a concrete subclass of a generic base class
class Base<T> {
  let t: T
  init(t: T) { self.t = t }
}
class Derived : Base<Int> {}
extension Derived {
  @objc func otherMethod() -> Int {
    return t
  }
}
let y: AnyObject = Derived(t: 100)
// CHECK: 100
// This call fails due to rdar://problem/47053588, where categories
// don't attach to a dynamically initialized Swift class, on macOS 10.9
// and iOS 7. Disable it for now when testing on those versions.
if #available(macOS 10.10, iOS 8, *) {
  print(y.otherMethod())
} else {
  print("100") // Hack to satisfy FileCheck.
}
extension NSObject {
  @objc func sillyMethod() -> Int {
    return 123
  }
}
let z: AnyObject = NSObject()
// CHECK: 123
print(z.sillyMethod())
// Category on an ObjC generic class using a type-pinning parameter, including
// a cast to an existential metatype
@objc protocol CacheNameDefaulting {
  static var defaultCacheName: String { get }
}
extension OuterClass.InnerClass: CacheNameDefaulting {
  static var defaultCacheName: String { "InnerClasses" }
}
extension NSCache {
  @objc convenience init(ofObjects objectTy: ObjectType.Type, forKeys keyTy: KeyType.Type) {
    self.init()
    if let defaultNameTy = objectTy as? CacheNameDefaulting.Type {
      self.name = defaultNameTy.defaultCacheName
    }
  }
}
let cache = NSCache(ofObjects: OuterClass.InnerClass.self, forKeys: NSString.self)
// CHECK: InnerClasses
print(cache.name)
 |