| // 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)); |
| } |