diff --git a/spec.html b/spec.html
index 8493c6364b..78b52d7903 100644
--- a/spec.html
+++ b/spec.html
@@ -37836,6 +37836,63 @@
RegExp.prototype
This property has the attributes { [[Writable]]: *false*, [[Enumerable]]: *false*, [[Configurable]]: *false* }.
+
+ RegExp.escape ( _S_ )
+ 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.
+ It performs the following steps when called:
+
+
+ 1. If _S_ is not a String, throw a TypeError exception.
+ 1. Let _escaped_ be the empty String.
+ 1. Let _cpList_ be StringToCodePoints(_S_).
+ 1. For each code point _c_ in _cpList_, do
+ 1. If _escaped_ is the empty String, and _c_ is matched by |DecimalDigit| or |AsciiLetter|, then
+ 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`.
+ 1. Let _numericValue_ be the numeric value of _c_.
+ 1. Let _hex_ be Number::toString(đť”˝(_numericValue_), 16).
+ 1. Assert: The length of _hex_ is 2.
+ 1. Set _escaped_ to the string-concatenation of the code unit 0x005C (REVERSE SOLIDUS), *"x"*, and _hex_.
+ 1. Else,
+ 1. Set _escaped_ to the string-concatenation of _escaped_ and EncodeForRegExpEscape(_c_).
+ 1. Return _escaped_.
+
+
+
+ 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.
+
+
+
+
+
+ EncodeForRegExpEscape (
+ _c_: a code point,
+ ): a String
+
+
+
+
+ 1. If _c_ is matched by |SyntaxCharacter| or _c_ is U+002F (SOLIDUS), then
+ 1. Return the string-concatenation of 0x005C (REVERSE SOLIDUS) and UTF16EncodeCodePoint(_c_).
+ 1. Else if _c_ is the code point listed in some cell of the “Code Point” column of , then
+ 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_.
+ 1. Let _otherPunctuators_ be the string-concatenation of *",-=<>#&!%:;@~'`"* and the code unit 0x0022 (QUOTATION MARK).
+ 1. Let _toEscape_ be StringToCodePoints(_otherPunctuators_).
+ 1. If _toEscape_ contains _c_, or _c_ is matched by |WhiteSpace| or |LineTerminator|, or _c_ has the same numeric value as a leading surrogate or trailing surrogate, then
+ 1. If _c_ ≤ 0xFF, then
+ 1. Let _hex_ be Number::toString(đť”˝(_c_), 16).
+ 1. Return the string-concatenation of the code unit 0x005C (REVERSE SOLIDUS), *"x"*, and StringPad(_hex_, 2, *"0"*, ~start~).
+ 1. Let _escaped_ be the empty String.
+ 1. Let _codeUnits_ be UTF16EncodeCodePoint(_c_).
+ 1. For each code unit _cu_ of _codeUnits_, do
+ 1. Set _escaped_ to the string-concatenation of _escaped_ and UnicodeEscape(_cu_).
+ 1. Return _escaped_.
+ 1. Return UTF16EncodeCodePoint(_c_).
+
+
+
get RegExp [ %Symbol.species% ]
`RegExp[%Symbol.species%]` is an accessor property whose set accessor function is *undefined*. Its get accessor function performs the following steps when called: