diff --git a/src/org/mozilla/javascript/regexp/NativeRegExp.java b/src/org/mozilla/javascript/regexp/NativeRegExp.java index 2b7cffdefe..c21e71d377 100644 --- a/src/org/mozilla/javascript/regexp/NativeRegExp.java +++ b/src/org/mozilla/javascript/regexp/NativeRegExp.java @@ -1847,7 +1847,8 @@ private static int simpleMatch( return -1; } - private static boolean executeREBytecode(REGlobalData gData, String input, int end) { + private static boolean executeREBytecode( + Context cx, REGlobalData gData, String input, int end) { int pc = 0; byte[] program = gData.regexp.program; int continuationOp = REOP_END; @@ -1877,6 +1878,7 @@ private static boolean executeREBytecode(REGlobalData gData, String input, int e } for (; ; ) { + ScriptRuntime.addInstructionCount(cx, 5); if (reopIsSimple(op)) { int match = simpleMatch(gData, input, op, program, pc, end, true); @@ -2306,6 +2308,7 @@ && simpleMatch(gData, input, op, program, pc, end, false) < 0) { } private static boolean matchRegExp( + Context cx, REGlobalData gData, RECompiled re, String input, @@ -2359,7 +2362,7 @@ && upcase(matchCh) == upcase((char) anchorCh))) { for (int j = 0; j < re.parenCount; j++) { gData.parens[j] = -1L; } - boolean result = executeREBytecode(gData, input, end); + boolean result = executeREBytecode(cx, gData, input, end); gData.backTrackStackTop = null; gData.stateStackTop = null; @@ -2393,7 +2396,7 @@ Object executeRegExp( // // Call the recursive matcher to do the real work. // - boolean matches = matchRegExp(gData, re, str, start, end, res.multiline); + boolean matches = matchRegExp(cx, gData, re, str, start, end, res.multiline); if (!matches) { if (matchType != PREFIX) return null; return Undefined.instance; diff --git a/testsrc/org/mozilla/javascript/tests/ObserveInstructionCountTest.java b/testsrc/org/mozilla/javascript/tests/ObserveInstructionCountTest.java index a83b351c6b..72d34115ea 100644 --- a/testsrc/org/mozilla/javascript/tests/ObserveInstructionCountTest.java +++ b/testsrc/org/mozilla/javascript/tests/ObserveInstructionCountTest.java @@ -118,4 +118,11 @@ public void forever() { String source = "for(;;);"; baseCase(source); } + + @Test + public void longRunningRegExp() { + String source = + "/(.*){1,32000}[bc]/.test(\"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\");"; + baseCase(source); + } }