Commit 1634e7de authored by yangguo@chromium.org's avatar yangguo@chromium.org

Fix assertion in RegExp parser to correctly expect stack overflow.

Advance() always checks for stack overflow. If stack indeed overflowed,
current() would hold the kEndMarker. ParseOctalLiteral does not expect
this in the assertion, which causes assertion failure.

R=mvstanton@chromium.org
BUG=350865
LOG=N

Review URL: https://codereview.chromium.org/192773002

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@19764 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 988d5fe5
...@@ -4990,7 +4990,7 @@ bool RegExpParser::ParseIntervalQuantifier(int* min_out, int* max_out) { ...@@ -4990,7 +4990,7 @@ bool RegExpParser::ParseIntervalQuantifier(int* min_out, int* max_out) {
uc32 RegExpParser::ParseOctalLiteral() { uc32 RegExpParser::ParseOctalLiteral() {
ASSERT('0' <= current() && current() <= '7'); ASSERT(('0' <= current() && current() <= '7') || current() == kEndMarker);
// For compatibility with some other browsers (not all), we parse // For compatibility with some other browsers (not all), we parse
// up to three octal digits with a value below 256. // up to three octal digits with a value below 256.
uc32 value = current() - '0'; uc32 value = current() - '0';
......
// Copyright 2014 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: --stress-compaction --stack-size=150
/\2/.test("1");
function rec() {
try {
rec();
} catch(e) {
/\2/.test("1");
}
}
rec();
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment