Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/tc39/proposal-regexp-x-mode


https://github.com/tc39/proposal-regexp-x-mode

Last synced: 2 months ago
JSON representation

Awesome Lists containing this project

README

        

# Regular Expression Extended Mode and Comments for ECMAScript

## Status

**Stage:** 1
**Champion:** Ron Buckton ([@rbuckton](https://github.com/rbuckton))

_For detailed status of this proposal see [TODO](#todo), below._

## Authors

* Ron Buckton ([@rbuckton](https://github.com/rbuckton))

# Motivations

The RegExp Extended mode is a feature commonly supported amongst multiple regular expression engines that makes it possible
to write regular expressions that are easier to read and understand through the introduction of insignificant white space
and comments.

# Prior Art

* Perl: [Comments](https://rbuckton.github.io/regexp-features/engines/perl.html#feature-comments),
[Line Comments](https://rbuckton.github.io/regexp-features/engines/perl.html#feature-line-comments)
* PCRE: [Comments](https://rbuckton.github.io/regexp-features/engines/pcre.html#feature-comments),
[Line Comments](https://rbuckton.github.io/regexp-features/engines/pcre.html#feature-line-comments)
* Boost.Regex: [Comments](https://rbuckton.github.io/regexp-features/engines/boost.regex.html#feature-comments)
* .NET: [Comments](https://rbuckton.github.io/regexp-features/engines/dotnet.html#feature-comments),
[Line Comments](https://rbuckton.github.io/regexp-features/engines/dotnet.html#feature-line-comments)
* Oniguruma: [Comments](https://rbuckton.github.io/regexp-features/engines/oniguruma.html#feature-comments)
* Hyperscan: [Comments](https://rbuckton.github.io/regexp-features/engines/hyperscan.html#feature-comments)
* ICU: [Comments](https://rbuckton.github.io/regexp-features/engines/icu.html#feature-comments),
[Line Comments](https://rbuckton.github.io/regexp-features/engines/icu.html#feature-line-comments)
* Glib/GRegex: [Comments](https://rbuckton.github.io/regexp-features/engines/glib-gregex.html#feature-comments),
[Line Comments](https://rbuckton.github.io/regexp-features/engines/glib-gregex.html#feature-line-comments)

See https://rbuckton.github.io/regexp-features/features/comments.html and
https://rbuckton.github.io/regexp-features/features/line-comments.html for additional information.

# Syntax

## Flags

### Extended mode (`x`)

**Prior Art:** Perl, PCRE, Boost.Regex, .NET, Oniguruma, Hyperscan, ICU, Glib/GRegex ([feature comparison](https://rbuckton.github.io/regexp-features/features/flags.html))

The extended mode (`x`) flag treats unescaped whitespace characters as insignificant, allowing for multi-line regular expressions. It also enables [Line Comments](#line-comments).

> NOTE: The `x`-mode flag can be used inside of a [Modifier](#modifiers)

> NOTE: While the `x`-mode flag can be used in a _RegularExpressionLiteral_, it does not permit the use of _LineTerminator_ in _RegularExpressonLiteral_. For multi-line
> regular expressions you would need to use the `RegExp` constructor.

> NOTE: Perl's original `x`-mode treated whitespace as insignificant anywhere within a pattern *except* for within character classes. Perl v5.26 introduced the `xx` flag which
> also ignores non-escaped SPACE and TAB characters. Should we chose to adopt the `x`-mode flag, we could opt to treat it as Perl's `xx` mode at the outset.

## Inline Comments

**Prior Art:** Perl, PCRE, Boost.Regex, .NET, Oniguruma, Hyperscan, ICU, Glib/GRegex ([feature comparison](https://rbuckton.github.io/regexp-features/features/comments.html))

An inline comment is a sequence of characters that is ignored by pattern matching and can be used to document a pattern.

- `(?#comment)` — The entire expression is removed from the pattern.
- The text of *comment* may not contain other `(` or `)` characters (instead, they must be escaped).
- When parsing a _RegularExpressionLiteral_, the text of *comment* also may not contain `/` (unless it is escaped).
- *NOTE: It may be necessary to escape `[` and `]` as well, unless we are able to change the definition for _RegularExpressionBody_ in the specification
so as to permit an unbalanced pair of `[` and `]` within *comment*. See [Issue #1](https://github.com/rbuckton/proposal-regexp-x-mode/issues/1).*

> NOTE: This has no conflicts with existing syntax, as ECMAScript currently produces an error for this syntax in both `u` and non-`u` modes.

## Line Comments

**Prior Art:** Perl, PCRE, .NET, ICU, Glib/GRegex ([feature comparison](https://rbuckton.github.io/regexp-features/features/line-comments.html))

A Line Comment is a sequence of characters starting with `#` and ending with `\n` (or the end of the pattern) that is ignored by pattern matching and can be used to document a pattern.

- `# comment` — A line comment in a multi-line RegExp

> NOTE: Requires the `x`-mode [flag](#extended-mode-x).

> NOTE: Inside of `x`-mode, the `#` character must be escaped (using `\#`) outside of a character class.

> NOTE: Not supported in `x` mode in a Regular Expression Literal

# Examples

## Insignificant Whitespace

```js
const re = /(foo) (bar) (baz)/x;
re.test("foobarbaz"); // true
```

## Comments

```js
const re = /foo(?#comment)bar/;
re.test("foobar"); // true
```

## Line Comments

```js
const re = new RegExp(String.raw`
# match ASCII alpha-numerics
[a-zA-Z0-9]
`, "x");
```

# API

## Flags

### Extended mode (`x`)

#### API

- `RegExp.prototype.extended` (Boolean) — Indicates the `x`-mode flag is set.

# History

- October 27th, 2021 — Proposed for Stage 1 ([slides](https://1drv.ms/p/s!AjgWTO11Fk-Tkfl_R_GWK0hIILFQDg?e=FjB377))
- Outcome: Advanced to Stage 1

# TODO

The following is a high-level list of tasks to progress through each stage of the [TC39 proposal process](https://tc39.github.io/process-document/):

### Stage 1 Entrance Criteria

* [x] Identified a "[champion][Champion]" who will advance the addition.
* [x] [Prose][Prose] outlining the problem or need and the general shape of a solution.
* [x] Illustrative [examples][Examples] of usage.
* [x] High-level [API][API].

### Stage 2 Entrance Criteria

* [ ] [Initial specification text][Specification].
* [ ] [Transpiler support][Transpiler] (_Optional_).

### Stage 3 Entrance Criteria

* [ ] [Complete specification text][Specification].
* [ ] Designated reviewers have [signed off][Stage3ReviewerSignOff] on the current spec text.
* [ ] The ECMAScript editor has [signed off][Stage3EditorSignOff] on the current spec text.

### Stage 4 Entrance Criteria

* [ ] [Test262](https://github.com/tc39/test262) acceptance tests have been written for mainline usage scenarios and [merged][Test262PullRequest].
* [ ] Two compatible implementations which pass the acceptance tests: [\[1\]][Implementation1], [\[2\]][Implementation2].
* [ ] A [pull request][Ecma262PullRequest] has been sent to tc39/ecma262 with the integrated spec text.
* [ ] The ECMAScript editor has signed off on the [pull request][Ecma262PullRequest].

[Process]: https://tc39.es/process-document/
[Proposals]: https://github.com/tc39/proposals/
[Grammarkdown]: http://github.com/rbuckton/grammarkdown#readme
[Champion]: #status
[Prose]: #motivations
[Examples]: #examples
[API]: #api
[Specification]: https://rbuckton.github.io/proposal-regexp-x-mode

[Transpiler]: #todo
[Stage3ReviewerSignOff]: #todo
[Stage3EditorSignOff]: #todo
[Test262PullRequest]: #todo
[Implementation1]: #todo
[Implementation2]: #todo
[Ecma262PullRequest]: #todo