session-ios/SessionUtilitiesKit/General/NSRegularExpression+SSK.swift

102 lines
3.1 KiB
Swift
Raw Normal View History

2019-01-10 19:21:33 +01:00
//
// Copyright (c) 2019 Open Whisper Systems. All rights reserved.
//
import Foundation
@objc
2020-12-18 01:57:11 +01:00
extension NSRegularExpression {
2019-01-10 19:21:33 +01:00
@objc
public func hasMatch(input: String) -> Bool {
return self.firstMatch(in: input, options: [], range: NSRange(location: 0, length: input.utf16.count)) != nil
}
2019-01-17 20:56:46 +01:00
@objc
2020-12-18 01:57:11 +01:00
public class func parseFirstMatch(pattern: String, text: String, options: NSRegularExpression.Options = []) -> String? {
2019-01-17 20:56:46 +01:00
do {
let regex = try NSRegularExpression(pattern: pattern, options: options)
2020-12-18 01:57:11 +01:00
guard let match = regex.firstMatch(in: text, options: [], range: NSRange(location: 0, length: text.utf16.count)) else {
return nil
2019-01-17 20:56:46 +01:00
}
let matchRange = match.range(at: 1)
guard let textRange = Range(matchRange, in: text) else {
return nil
}
let substring = String(text[textRange])
return substring
} catch {
return nil
}
}
2019-03-15 02:24:15 +01:00
@objc
2020-12-18 01:57:11 +01:00
public func parseFirstMatch(inText text: String, options: NSRegularExpression.Options = []) -> String? {
2019-03-15 02:24:15 +01:00
guard let match = self.firstMatch(in: text,
options: [],
range: NSRange(location: 0, length: text.utf16.count)) else {
return nil
}
let matchRange = match.range(at: 1)
guard let textRange = Range(matchRange, in: text) else {
return nil
}
let substring = String(text[textRange])
return substring
}
2020-11-03 23:56:28 +01:00
@nonobjc
2020-12-18 01:57:11 +01:00
public func firstMatchSet(in searchString: String) -> MatchSet? {
2020-11-03 23:56:28 +01:00
firstMatch(in: searchString, options: [], range: searchString.completeNSRange)?.createMatchSet(originalSearchString: searchString)
}
@nonobjc
2020-12-18 01:57:11 +01:00
public func allMatchSets(in searchString: String) -> [MatchSet] {
2020-11-03 23:56:28 +01:00
matches(in: searchString, options: [], range: searchString.completeNSRange).compactMap { $0.createMatchSet(originalSearchString: searchString) }
}
}
public struct MatchSet {
2020-12-18 01:57:11 +01:00
public let fullString: Substring
public let matchedGroups: [Substring?]
2020-11-03 23:56:28 +01:00
2020-12-18 01:57:11 +01:00
public func group(idx: Int) -> Substring? {
2020-11-03 23:56:28 +01:00
guard idx < matchedGroups.count else { return nil }
return matchedGroups[idx]
}
}
2020-12-18 01:57:11 +01:00
extension String {
public subscript(_ nsRange: NSRange) -> Substring? {
2020-11-03 23:56:28 +01:00
guard let swiftRange = Range(nsRange, in: self) else { return nil }
return self[swiftRange]
}
2020-12-18 01:57:11 +01:00
public var completeRange: Range<String.Index> {
2020-11-03 23:56:28 +01:00
startIndex..<endIndex
}
2020-12-18 01:57:11 +01:00
public var completeNSRange: NSRange {
2020-11-03 23:56:28 +01:00
NSRange(completeRange, in: self)
}
2019-01-10 19:21:33 +01:00
}
2020-11-03 23:56:28 +01:00
2020-12-18 01:57:11 +01:00
extension NSTextCheckingResult {
public func createMatchSet(originalSearchString string: String) -> MatchSet? {
2020-11-03 23:56:28 +01:00
guard numberOfRanges > 0 else { return nil }
let substrings = (0..<numberOfRanges)
.map { range(at: $0) }
.map { string[$0] }
guard let fullString = substrings[0] else {
return nil
}
return MatchSet(fullString: fullString, matchedGroups: Array(substrings[1...]))
}
}