mirror of
https://github.com/nodejs/node.git
synced 2025-05-15 12:45:25 +00:00

PR-URL: https://github.com/nodejs/node/pull/36139 Reviewed-By: Jiawen Geng <technicalcute@gmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Myles Borins <myles.borins@gmail.com> Reviewed-By: Shelley Vohr <codebytere@gmail.com>
33 lines
1.1 KiB
JavaScript
33 lines
1.1 KiB
JavaScript
// Copyright 2019 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 --no-enable-experimental-regexp-engine
|
|
// Flags: --no-enable-experimental-regexp-engine-on-excessive-backtracks
|
|
|
|
const kNoBacktrackLimit = 0; // To match JSRegExp::kNoBacktrackLimit.
|
|
const re0 = %NewRegExpWithBacktrackLimit("(\\d+)+x", "", kNoBacktrackLimit);
|
|
const re1 = %NewRegExpWithBacktrackLimit("(\\d+)+x", "", 50);
|
|
|
|
// Backtracks remain below the limit on this subject string.
|
|
{
|
|
let s = "3333ax3333x";
|
|
assertArrayEquals(["3333x", "3333"], re0.exec(s));
|
|
assertEquals(["3333x", "3333"], re1.exec(s));
|
|
}
|
|
|
|
// A longer subject exceeds the limit.
|
|
{
|
|
let s = "333333333ax3333x";
|
|
assertArrayEquals(["3333x", "3333"], re0.exec(s));
|
|
assertEquals(null, re1.exec(s));
|
|
}
|
|
|
|
// ATOM regexp construction with a limit; in this case the limit should just be
|
|
// ignored, ATOMs never backtrack.
|
|
{
|
|
const re = %NewRegExpWithBacktrackLimit("ax", "", 50);
|
|
let s = "3333ax3333x";
|
|
assertArrayEquals(["ax"], re.exec(s));
|
|
}
|