Files
swift-mirror/test/StringProcessing/Runtime/regex_basic.swift
Richard Wei e5175d595e [Regex] Infer 'Match' type of regex literals.
Applies swift-experimental-string-processing#68 in regex literal type inference. Regex literals with captures will have type `Regex<Tuple{n}<Substring, {Captures...}>>`. This is a temporary thing that allows us to define generic constraints on captures. We will switch back to native tuples once we have variadic generics.
2022-01-06 10:54:10 -08:00

61 lines
1.6 KiB
Swift

// RUN: %target-run-simple-swift(-Xfrontend -enable-experimental-string-processing)
// REQUIRES: swift_in_compiler,string_processing,executable_test
import StdlibUnittest
var RegexBasicTests = TestSuite("RegexBasic")
extension String {
func expectMatch<T>(
_ regex: Regex<T>,
file: String = #file,
line: UInt = #line
) -> RegexMatch<T> {
guard let result = match(regex) else {
expectUnreachable("Failed match", file: file, line: line)
fatalError()
}
return result
}
}
RegexBasicTests.test("Basic") {
let input = "aabccd"
let match1 = input.expectMatch('/aabcc./')
expectEqual("aabccd", input[match1.range])
expectTrue("aabccd" == match1.match)
let match2 = input.expectMatch('/a*b.+./')
expectEqual("aabccd", input[match2.range])
expectTrue("aabccd" == match2.match)
}
RegexBasicTests.test("Modern") {
let input = "aabccd"
let match1 = input.expectMatch('|a a bc c /*hello*/ .|')
expectEqual("aabccd", input[match1.range])
expectTrue("aabccd" == match1.match)
}
RegexBasicTests.test("Captures") {
let input = """
A6F0..A6F1 ; Extend # Mn [2] BAMUM COMBINING MARK KOQNDON..BAMUM \
COMBINING MARK TUKWENTIS
"""
let regex = '/([0-9A-F]+)(?:\.\.([0-9A-F]+))?\s+;\s+(\w+).*/'
// Test inferred type.
let _: Regex<Tuple4<Substring, Substring, Substring?, Substring>>.Type
= type(of: regex)
let match1 = input.expectMatch(regex)
expectEqual(input[...], input[match1.range])
expectTrue(input == match1.0)
expectTrue("A6F0" == match1.1)
expectTrue("A6F1" == match1.2)
expectTrue("Extend" == match1.3)
}
runAllTests()