mirror of
https://github.com/Dimillian/IceCubesApp.git
synced 2025-01-11 08:35:26 +00:00
Faster HTML String disk cache
This commit is contained in:
parent
d7bad26f04
commit
0af60c4b1e
1 changed files with 51 additions and 31 deletions
|
@ -2,22 +2,38 @@ import Foundation
|
||||||
import SwiftSoup
|
import SwiftSoup
|
||||||
import SwiftUI
|
import SwiftUI
|
||||||
|
|
||||||
|
fileprivate enum CodingKeys: CodingKey {
|
||||||
|
case htmlValue, asMarkdown, asRawText, statusesURLs
|
||||||
|
}
|
||||||
|
|
||||||
public struct HTMLString: Codable, Equatable, Hashable {
|
public struct HTMLString: Codable, Equatable, Hashable {
|
||||||
public var htmlValue: String = ""
|
public var htmlValue: String = ""
|
||||||
public var asMarkdown: String = ""
|
public var asMarkdown: String = ""
|
||||||
public var asRawText: String = ""
|
public var asRawText: String = ""
|
||||||
public var statusesURLs = [URL]()
|
public var statusesURLs = [URL]()
|
||||||
|
|
||||||
public var asSafeMarkdownAttributedString: AttributedString = .init()
|
public var asSafeMarkdownAttributedString: AttributedString = .init()
|
||||||
private var regex: NSRegularExpression?
|
private var regex: NSRegularExpression?
|
||||||
|
|
||||||
public init(from decoder: Decoder) {
|
public init(from decoder: Decoder) {
|
||||||
|
var alreadyDecoded: Bool = false
|
||||||
do {
|
do {
|
||||||
let container = try decoder.singleValueContainer()
|
let container = try decoder.singleValueContainer()
|
||||||
htmlValue = try container.decode(String.self)
|
htmlValue = try container.decode(String.self)
|
||||||
|
} catch {
|
||||||
|
do {
|
||||||
|
alreadyDecoded = true
|
||||||
|
let container = try decoder.container(keyedBy: CodingKeys.self)
|
||||||
|
htmlValue = try container.decode(String.self, forKey: .htmlValue)
|
||||||
|
asMarkdown = try container.decode(String.self, forKey: .asMarkdown)
|
||||||
|
asRawText = try container.decode(String.self, forKey: .asRawText)
|
||||||
|
statusesURLs = try container.decode([URL].self, forKey: .statusesURLs)
|
||||||
} catch {
|
} catch {
|
||||||
htmlValue = ""
|
htmlValue = ""
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if !alreadyDecoded {
|
||||||
// https://daringfireball.net/projects/markdown/syntax
|
// https://daringfireball.net/projects/markdown/syntax
|
||||||
// Pre-escape \ ` _ * and [ as these are the only
|
// Pre-escape \ ` _ * and [ as these are the only
|
||||||
// characters the markdown parser used picks up
|
// characters the markdown parser used picks up
|
||||||
|
@ -48,6 +64,7 @@ public struct HTMLString: Codable, Equatable, Hashable {
|
||||||
} catch {
|
} catch {
|
||||||
asRawText = htmlValue
|
asRawText = htmlValue
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
do {
|
do {
|
||||||
let options = AttributedString.MarkdownParsingOptions(allowsExtendedAttributes: true,
|
let options = AttributedString.MarkdownParsingOptions(allowsExtendedAttributes: true,
|
||||||
|
@ -67,8 +84,11 @@ public struct HTMLString: Codable, Equatable, Hashable {
|
||||||
}
|
}
|
||||||
|
|
||||||
public func encode(to encoder: Encoder) throws {
|
public func encode(to encoder: Encoder) throws {
|
||||||
var container = encoder.singleValueContainer()
|
var container = encoder.container(keyedBy: CodingKeys.self)
|
||||||
try container.encode(htmlValue)
|
try container.encode(htmlValue, forKey: .htmlValue)
|
||||||
|
try container.encode(asMarkdown, forKey: .asMarkdown)
|
||||||
|
try container.encode(asRawText, forKey: .asRawText)
|
||||||
|
try container.encode(statusesURLs, forKey: .statusesURLs)
|
||||||
}
|
}
|
||||||
|
|
||||||
private mutating func handleNode(node: SwiftSoup.Node) {
|
private mutating func handleNode(node: SwiftSoup.Node) {
|
||||||
|
|
Loading…
Reference in a new issue