Метод Swizzling в Swift 4
Swizzling в Swift 4 больше не работает.
Method 'initialize()' defines Objective-C class method 'initialize', which is not permitted by Swift
Это то, что я нашел решение, поэтому хотел оставить вопросы и ответить для других.
1 ответ
initialize() больше не выставляется: Method 'initialize()' defines Objective-C class method 'initialize', which is not permitted by Swift
Таким образом, способ сделать это сейчас - запустить ваш swizzle-код с помощью публичного статического метода.
например
В расширении: (Это расширение используется в открытом исходном коде кикстарта: https://github.com/kickstarter/ios-oss/blob/master/Library/DataSource/UIView-Extensions.swift)
private var hasSwizzled = false
extension UIView {
final public class func doBadSwizzleStuff() {
guard !hasSwizzled else { return }
hasSwizzled = true
swizzle(self) /* This is pseudo - run your method here */
}
}
В приложении делегат: (Этот метод используется в открытом исходном коде Kickstarted: https://github.com/kickstarter/ios-oss/blob/7c827770813e25cc7f79a28fa151cd713efe936f/Kickstarter-iOS/AppDelegate.swift)
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: UIApplicationLaunchOptionsKey: Any]?) -> Bool
{
UIView.doBadSwizzleStuff()
}
Другой способ - использовать синглтон:
extension UIView {
static let shared : UIViewController = {
$0.initialize()
return $0
}(UIViewController())
func initialize() {
// make sure this isn't a subclass
guard self === UIViewController.self else { return }
let swizzleClosure: () = {
UIViewController().swizzle() /* This is pseudo - run your method here */
}()
swizzleClosure
}
}
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: UIApplicationLaunchOptionsKey: Any]?) -> Bool
{
_ = UIViewController.shared
}