a27a42f5ae
This is a reland of 3ca32e9828
Original change's description:
> [regexp] Introduce species constructor protector for regexps.
>
> Bug: v8:8445
> Change-Id: Iea69c65d0054b24b3f8c7234c4c556ebee2dd45f
> Reviewed-on: https://chromium-review.googlesource.com/c/1335696
> Reviewed-by: Jakob Gruber <jgruber@chromium.org>
> Reviewed-by: Ulan Degenbaev <ulan@chromium.org>
> Commit-Queue: Jaroslav Sevcik <jarin@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#57564}
Bug: v8:8445
Change-Id: Ib79d716ff857eed95eed800b33ccb53f33d5167f
Reviewed-on: https://chromium-review.googlesource.com/c/1340286
Reviewed-by: Jakob Gruber <jgruber@chromium.org>
Reviewed-by: Ulan Degenbaev <ulan@chromium.org>
Commit-Queue: Jaroslav Sevcik <jarin@chromium.org>
Cr-Commit-Position: refs/heads/master@{#57598}
28 lines
748 B
JavaScript
28 lines
748 B
JavaScript
// Copyright 2018 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: --allow-natives-syntax --harmony-string-matchall
|
|
|
|
class MyRegExp {
|
|
exec() { return null; }
|
|
}
|
|
|
|
var r = /c/;
|
|
|
|
assertEquals(["ab", ""], "abc".split(r));
|
|
assertEquals([["c"]], [..."c".matchAll(r)]);
|
|
|
|
r.constructor = { [Symbol.species] : MyRegExp };
|
|
|
|
assertEquals(["abc"], "abc".split(r));
|
|
assertEquals([], [..."c".matchAll(r)]);
|
|
|
|
assertEquals(["ab", ""], "abc".split(/c/));
|
|
assertEquals([["c"]], [..."c".matchAll(/c/)]);
|
|
|
|
RegExp.prototype.constructor = { [Symbol.species] : MyRegExp };
|
|
|
|
assertEquals(["abc"], "abc".split(/c/));
|
|
assertEquals([], [..."c".matchAll(/c/)]);
|