v8/test/mjsunit/regress/regress-crbug-482998.js
erikcorry 05507cc3ea Reland II of 'Optimize trivial regexp disjunctions' CL 1176453002
This change rewrites regexps like (ab|ac|z|ad|ae|af) into (a[b-f]|z).  We can only reorder disjunctions like this for case-dependent regexps.  For case-independent regexps, the disjunctions should be pre-sorted for best results.

R=yangguo@chromium.org
BUG=chromium:482998
LOG=n

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

Cr-Commit-Position: refs/heads/master@{#28902}
2015-06-10 09:55:31 +00:00

23 lines
641 B
JavaScript

// Copyright 2015 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.
// Should not time out. Running time 0.5s vs. 120s before the change.
function collapse() {
var src = "(?:";
for (var i = 128; i < 0x1000; i++) {
src += "a" + String.fromCharCode(i) + "|";
}
src += "aa)";
var collapsible = new RegExp(src);
var subject = "zzzzzzz" + String.fromCharCode(3000);
for (var i = 0; i < 1000; i++) {
subject += "xxxxxxx";
}
for (var i = 0; i < 2000; i++) {
assertFalse(collapsible.test(subject));
}
}
collapse();