This changelog summarizes major changes between TRegex versions relevant to language implementors integrating TRegex into their language. This document will focus on API changes relevant to integrators of TRegex.
- Implemented the Regular Expression Pattern Modifiers proposal for ECMAScript regular expressions.
- Added support for atomic groups and possessive quantifiers in Python regular expressions.
- Added support for Unicode sets mode (
v
flag) in ECMAScript regular expressions. - Added support for duplicate named capturing groups in ECMAScript regular expressions.
- Updated Unicode data (case-folding, character properties) to version 15 of the Unicode standard.
- Dropped
Flavor=PythonStr
andFlavor=PythonBytes
in favor ofFlavor=Python,Encoding=UTF-32
andFlavor=Python,Encoding=LATIN-1
. - Dropped support for the
execBytes(byte[] input, int fromIndex)
entrypoint. - Dropped support for
TruffleObject
s with characters/code points as array elements. - Added support for conditional back-references (e.g.
(foo)(?(1)bar|no_foo)
) in Python and Ruby regular expressions. - Added support for case-insensitive back-references in Python and Ruby regular expressions.
- Added support for locale-sensitive Python regular expressions.
- TRegex is no longer included by default in the GraalVM download and needs to be installed as a component using gu install regex.
- Added support for atomic groups and possessive quantifiers in Ruby regular expressions by using the backtracking.
- Added a
lastGroup
field to regex results. Its value is tracked when using the Python regex dialect and it indicates the last capture group to have been matched. - Added boolean matching mode (
execBoolean
), which allows omittingRegexResult
objects in cases where capture groups are known to never be queried. - Added
MustAdvance
andPythonMode
options for better Python support. - Support for named character escapes in Python regular expressions.
- Limited support for \G anchors in Ruby regular expressions.
- Dropped sticky flag from Python regular expressions.
- Added support for non-recursive subexpression calls in Ruby regular expressions.
- Added new
ASCII
encoding that callers can use when compiling a regex to limit the range of code point matches to [0x00, 0x7f]. - Updated Unicode data (case-folding, character properties) to version 14 of the Unicode standard.
- Support for case-insensitive matching in Ruby regular expressions.
- Added Regexp option IgnoreAtomicGroups for treating atomic groups as ordinary groups.
- Compiled regular expressions export the
isBacktracking
boolean member, which can be used to determine if the regexp can backtrack and potentially lead to exponential runtime.
- Added support for the
hasIndices
(d
) flag in ECMAScript regular expressions.
- Introduced on-the-fly decoding for UTF-16 strings.
- Completed feature support for EcmaScript 2020 regular expressions via a new built-in back-tracking engine.
- Removed properties
regex
,input
,start
, andend
from result objects. - Introduced methods
getStart(groupNumber)
andgetEnd(groupNumber)
as a replacement forstart
andend
in result objects. - Regex syntax exceptions are now to be treated as plain
TruffleException
s - languages using TRegex should not introduce any source code dependency on TRegex. - Moved
groupCount
property from regex result to compiled regex objects.
- Added the possibility to log the actions of the compiler.
- Introduced the
regex
loggersSwitchToEager
,TotalCompilationTime
,Phases
,BailoutMessages
,AutomatonSizes
,CompilerFallback
,InternalErrors
andTRegexCompilations
. These can be enabled in your launchers by setting, e.g.,--log.regex.Phases.level=ALL
.
- Introduced the