Skip to content

Latest commit

 

History

History
76 lines (49 loc) · 4 KB

CHANGELOG.md

File metadata and controls

76 lines (49 loc) · 4 KB

TRegex Changelog

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.

Version 24.2.0

Version 24.0.0

  • Added support for atomic groups and possessive quantifiers in Python regular expressions.

Version 23.1.0

  • Added support for Unicode sets mode (v flag) in ECMAScript regular expressions.
  • Added support for duplicate named capturing groups in ECMAScript regular expressions.

Version 23.0.0

  • Updated Unicode data (case-folding, character properties) to version 15 of the Unicode standard.
  • Dropped Flavor=PythonStr and Flavor=PythonBytes in favor of Flavor=Python,Encoding=UTF-32 and Flavor=Python,Encoding=LATIN-1.
  • Dropped support for the execBytes(byte[] input, int fromIndex) entrypoint.
  • Dropped support for TruffleObjects 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.

Version 22.2.0

  • Added support for atomic groups and possessive quantifiers in Ruby regular expressions by using the backtracking.

Version 22.1.0

  • 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 omitting RegexResult objects in cases where capture groups are known to never be queried.
  • Added MustAdvance and PythonMode 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.

Version 22.0.0

  • 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.

Version 21.3.0

  • 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.

Version 21.2.0

  • Added support for the hasIndices (d) flag in ECMAScript regular expressions.

Version 20.2.0

  • Introduced on-the-fly decoding for UTF-16 strings.

Version 20.1.0

  • Completed feature support for EcmaScript 2020 regular expressions via a new built-in back-tracking engine.

Version 1.0.0 RC15

  • Removed properties regex, input, start, and end from result objects.
  • Introduced methods getStart(groupNumber) and getEnd(groupNumber) as a replacement for start and end in result objects.
  • Regex syntax exceptions are now to be treated as plain TruffleExceptions - languages using TRegex should not introduce any source code dependency on TRegex.
  • Moved groupCount property from regex result to compiled regex objects.

Version 1.0.0 RC10

  • Added the possibility to log the actions of the compiler.
    • Introduced the regex loggers SwitchToEager, TotalCompilationTime, Phases, BailoutMessages, AutomatonSizes, CompilerFallback, InternalErrors and TRegexCompilations. These can be enabled in your launchers by setting, e.g., --log.regex.Phases.level=ALL.