mirror of
https://github.com/ghostty-org/ghostty.git
synced 2025-08-02 14:57:31 +03:00
macos: use securecoding for codablebridge to prevent warning
Thanks Matt Polzin!
This commit is contained in:
@ -8,10 +8,7 @@ class CodableBridge<Wrapped: Codable>: NSObject, NSSecureCoding {
|
|||||||
static var supportsSecureCoding: Bool { return true }
|
static var supportsSecureCoding: Bool { return true }
|
||||||
|
|
||||||
required init?(coder aDecoder: NSCoder) {
|
required init?(coder aDecoder: NSCoder) {
|
||||||
// TODO: This outputs a warning with deprecation on decode. I don't know how to
|
guard let data = aDecoder.decodeObject(of: NSData.self, forKey: "data") as? Data else { return nil }
|
||||||
// fix that yet but there must be something we can change with the encode/decode here
|
|
||||||
// to resolve it.
|
|
||||||
guard let data = aDecoder.decodeData() else { return nil }
|
|
||||||
guard let archiver = try? NSKeyedUnarchiver(forReadingFrom: data) else { return nil }
|
guard let archiver = try? NSKeyedUnarchiver(forReadingFrom: data) else { return nil }
|
||||||
guard let value = archiver.decodeDecodable(Wrapped.self, forKey: "value") else { return nil }
|
guard let value = archiver.decodeDecodable(Wrapped.self, forKey: "value") else { return nil }
|
||||||
self.value = value
|
self.value = value
|
||||||
@ -20,6 +17,6 @@ class CodableBridge<Wrapped: Codable>: NSObject, NSSecureCoding {
|
|||||||
func encode(with aCoder: NSCoder) {
|
func encode(with aCoder: NSCoder) {
|
||||||
let archiver = NSKeyedArchiver(requiringSecureCoding: true)
|
let archiver = NSKeyedArchiver(requiringSecureCoding: true)
|
||||||
try? archiver.encodeEncodable(value, forKey: "value")
|
try? archiver.encodeEncodable(value, forKey: "value")
|
||||||
aCoder.encode(archiver.encodedData)
|
aCoder.encode(archiver.encodedData, forKey: "data")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user