837e374eac
This patch implements one aspect of ES2015 RegExp subclassing: String.prototype.replace is separated into two parts, a method on RegExp.prototype in case the first argument is a RegExp, and the String.prototype.replace method, which handles the string pattern case. This separation is described in the ES2015 specification. Most of the patch is simply moving code from string.js to regexp.js. R=yangguo LOG=Y BUG=v8:4343 Review URL: https://codereview.chromium.org/1590673002 Cr-Commit-Position: refs/heads/master@{#33393}
20 lines
690 B
JavaScript
20 lines
690 B
JavaScript
// Copyright 2015 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// Flags: --harmony-regexp-subclass
|
|
|
|
var pattern = {
|
|
[Symbol.replace]: (string, newValue) => string + newValue
|
|
};
|
|
// Check object coercible fails.
|
|
assertThrows(() => String.prototype.replace.call(null, pattern, "x"),
|
|
TypeError);
|
|
// Override is called.
|
|
assertEquals("abcdex", "abcde".replace(pattern, "x"));
|
|
// Non-callable override.
|
|
pattern[Symbol.replace] = "dumdidum";
|
|
assertThrows(() => "abcde".replace(pattern, "x"), TypeError);
|
|
|
|
assertEquals("[Symbol.replace]", RegExp.prototype[Symbol.replace].name);
|