File: objc_extensions.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 (88 lines) | stat: -rw-r--r-- 1,933 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
// 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)