Regular expression utilities for Koto.
|String| -> Regex
Creates a new Regex from the given string.
The core regular expression type used by the regex
module.
The regex
module is a wrapper for the regex
crate,
please see its documentation for more information,
including a guide to the supported syntax.
|Regex, input: String| -> Bool
Returns true
if the given input
string matches against the regular
expression.
r = regex.new r'x\d\d'
r.is_match 'x42'
# -> true
r.is_match 'z99'
# -> false
|Regex, input: String| -> Match?
If the given input
string matches the regular expression, then an instance of
Match
is returned that allows the first matched region in the string
to be inspected. If no matches are found then null
is returned.
# Make a regex that will match against any group of 2 or 3 a-z characters
r = regex.new r'[a-z]{2,3}'
found = r.find 'a b xyz jk mno'
found.text(), found.range()
# -> ('xyz', 4..7)
r.find '12345'
# -> null
|Regex, input: String| -> Matches?
If the given input
string matches the regular expression, then an instance of
Matches
is returned that allows all matches in the input to be
inspected. If no matches are found then null
is returned.
# Make a regex that will match against any group of 2 or 3 a-z characters
r = regex.new r'[a-z]{2,3}'
matches = r.find_all('a bc def gh')
for found in matches
print found.text(), found.range()
# -> ('bc', 2..4)
# -> ('def', 5..8)
# -> ('gh', 9..11)
|Regex, input: String| -> Map?
If the given string matches the regular expression, then a map is returned
containing the first match found, along with matches for any capture groups.
If no matches are found then null
is returned.
Captured groups are entered in the map with their indices as the key, and if the group is named then it's also inserted with the name. The first entry in the map (index 0) contains the entire match, with subsequent captures starting at index 1.
# Make a regex that will match against two words inside <> braces
r = regex.new r'<(?<group_a>\S+)\s+(\S+)>'
captures = r.captures '!!! <Hello, World!> ???'
# Entry 0 contains the complete match
captures.get(0).text()
# -> <Hello, World!>
# Named captured groups use the name as the map key
captures.group_a.text()
# -> Hello,
# Groups without names use their group index as the map key
captures.get(2).text()
# -> World!
# Named capture groups are also available by index
group_name, capture = captures.get_index(1)
group_name, capture.text()
# -> ('group_a', 'Hello,')
|Regex, input: String, replacement: String| -> String
Returns a string with each match in the input replaced using rules defined in the replacement string.
# Make a regex that will match against two words inside <> braces
r = regex.new r'<(?<a>\S+)\s+(?<b>\S+)>'
r.replace_all '!!! <Replace Me> !!!', '>_>'
# -> !!! >_> !!!
# Capture groups can be referred to in the replacement string
r.replace_all '!!! <AAA BBB> !!!', '[$a$b $a$b]'
# -> !!! [AAABBB AAABBB] !!!
Matches
is an iterator that outputs a Match
for each match
resulting from a call to Regex.find_all
.
Match
is a type produced from calls to search functions like
Regex.find
or Regex.captures
that provides
access to the matched region of the input string,
along with the matched region's indices.
|Match| -> String
Returns the matched region of the input string.
m = regex.new(r'x\d\d').find 'abc def x99 123'
m.text()
# -> x99
|Match| -> Range
Returns the indices of the matched region in the input string.
m = regex.new(r'x\d\d').find 'abc def x99 123'
m.range()
# -> 8..11