You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Copy file name to clipboardexpand all lines: spec.html
+57
Original file line number
Diff line number
Diff line change
@@ -37830,6 +37830,63 @@ <h1>Properties of the RegExp Constructor</h1>
37830
37830
<li>has the following properties:</li>
37831
37831
</ul>
37832
37832
37833
+
<emu-clause id="sec-regexp.escape">
37834
+
<h1>RegExp.escape ( _S_ )</h1>
37835
+
<p>This function returns a copy of _S_ in which characters that are potentially special in a regular expression |Pattern| have been replaced by equivalent escape sequences.</p>
37836
+
<p>It performs the following steps when called:</p>
37837
+
37838
+
<emu-alg>
37839
+
1. If _S_ is not a String, throw a *TypeError* exception.
37840
+
1. Let _escaped_ be the empty String.
37841
+
1. Let _cpList_ be StringToCodePoints(_S_).
37842
+
1. For each code point _c_ of _cpList_, do
37843
+
1. If _escaped_ is the empty String and _c_ is matched by either |DecimalDigit| or |AsciiLetter|, then
37844
+
1. NOTE: Escaping a leading digit ensures that output corresponds with pattern text which may be used after a `\0` character escape or a |DecimalEscape| such as `\1` and still match _S_ rather than be interpreted as an extension of the preceding escape sequence. Escaping a leading ASCII letter does the same for the context after `\c`.
37845
+
1. Let _numericValue_ be the numeric value of _c_.
37846
+
1. Let _hex_ be Number::toString(𝔽(_numericValue_), 16).
37847
+
1. Assert: The length of _hex_ is 2.
37848
+
1. Set _escaped_ to the string-concatenation of the code unit 0x005C (REVERSE SOLIDUS), *"x"*, and _hex_.
37849
+
1. Else,
37850
+
1. Set _escaped_ to the string-concatenation of _escaped_ and EncodeForRegExpEscape(_c_).
37851
+
1. Return _escaped_.
37852
+
</emu-alg>
37853
+
37854
+
<emu-note>
37855
+
<p>Despite having similar names, EscapeRegExpPattern and `RegExp.escape` do not perform similar actions. The former escapes a pattern for representation as a string, while this function escapes a string for representation inside a pattern.</p>
<dd>It returns a string representing a |Pattern| for matching _c_. If _c_ is white space or an ASCII punctuator, the returned value is an escape sequence. Otherwise, the returned value is a string representation of _c_ itself.</dd>
37867
+
</dl>
37868
+
37869
+
<emu-alg>
37870
+
1. If _c_ is matched by |SyntaxCharacter| or _c_ is U+002F (SOLIDUS), then
37871
+
1. Return the string-concatenation of 0x005C (REVERSE SOLIDUS) and UTF16EncodeCodePoint(_c_).
37872
+
1. Else if _c_ is the code point listed in some cell of the “Code Point” column of <emu-xref href="#table-controlescape-code-point-values"></emu-xref>, then
37873
+
1. Return the string-concatenation of 0x005C (REVERSE SOLIDUS) and the string in the “ControlEscape” column of the row whose “Code Point” column contains _c_.
37874
+
1. Let _otherPunctuators_ be the string-concatenation of *",-=<>#&!%:;@~'`"* and the code unit 0x0022 (QUOTATION MARK).
37875
+
1. Let _toEscape_ be StringToCodePoints(_otherPunctuators_).
37876
+
1. If _toEscape_ contains _c_, _c_ is matched by |WhiteSpace| or |LineTerminator|, or _c_ has the same numeric value as a leading surrogate or trailing surrogate, then
37877
+
1. If the numeric value of _c_ ≤ 0xFF, then
37878
+
1. Let _hex_ be Number::toString(𝔽(_c_), 16).
37879
+
1. Return the string-concatenation of the code unit 0x005C (REVERSE SOLIDUS), *"x"*, and StringPad(_hex_, 2, *"0"*, ~start~).
37880
+
1. Let _escaped_ be the empty String.
37881
+
1. Let _codeUnits_ be UTF16EncodeCodePoint(_c_).
37882
+
1. For each code unit _cu_ of _codeUnits_, do
37883
+
1. Set _escaped_ to the string-concatenation of _escaped_ and UnicodeEscape(_cu_).
37884
+
1. Return _escaped_.
37885
+
1. Return UTF16EncodeCodePoint(_c_).
37886
+
</emu-alg>
37887
+
</emu-clause>
37888
+
</emu-clause>
37889
+
37833
37890
<emu-clause id="sec-regexp.prototype">
37834
37891
<h1>RegExp.prototype</h1>
37835
37892
<p>The initial value of `RegExp.prototype` is the RegExp prototype object.</p>
0 commit comments