Skip to content
This repository has been archived by the owner. It is now read-only.
Permalink
firefox-merge-…
Switch branches/tags
Go to file
 
 
Cannot retrieve contributors at this time
executable file 37 lines (31 sloc) 1.5 KB
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
import Shared
// Workaround for bug 1417152, whereby NaN bounds are being set on the scrollview when viewing PDFs in the web view.
// Is fixed in WebKit, remove this file when the fix arrives in iOS release.
private let swizzling: (UIScrollView.Type) -> Void = { obj in
let originalSelector = #selector(setter: UIView.bounds)
let swizzledSelector = #selector(obj.swizzle_setBounds(bounds:))
let originalMethod = class_getInstanceMethod(obj, originalSelector)
let swizzledMethod = class_getInstanceMethod(obj, swizzledSelector)
method_exchangeImplementations(originalMethod, swizzledMethod)
}
extension UIScrollView {
open override class func initialize() {
// make sure this isn't a subclass
guard self == UIScrollView.self else {
return
}
swizzling(self)
}
func swizzle_setBounds(bounds: CGRect) {
let validSize = [bounds.origin.x, bounds.origin.y, bounds.size.width, bounds.size.height].every({ !$0.isNaN })
let validBounds = [bounds.size.width, bounds.size.height].every({ $0 >= 0 })
guard validBounds && validSize && !bounds.isInfinite else {
Sentry.shared.send(message: "Bad scrollview bounds detected [negative size].")
return
}
self.swizzle_setBounds(bounds: bounds)
}
}