WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
60866
Evaluation order broken for empty alternatives in subpatterns
https://bugs.webkit.org/show_bug.cgi?id=60866
Summary
Evaluation order broken for empty alternatives in subpatterns
Gavin Barraclough
Reported
2011-05-15 19:28:57 PDT
for example: /(|a)/.exec("a"); should return ["",""], but instead returns ["a","a"]. This was broken by
https://bugs.webkit.org/show_bug.cgi?id=51395
, which will be reverted (this unsafe optimization does not appear significant to any benchmarks we are tracking, we should reimplement in a more restricted, safe fashion only if we can demonstrate an important workload benefitting from doing so).
Attachments
Add attachment
proposed patch, testcase, etc.
Gavin Barraclough
Comment 1
2011-05-15 19:33:28 PDT
This unsafe optimization is masking further problems in the JIT, reverting the optimization causes failures in fast/regex/parentheses. These issues are fixed by 60860.
Geoffrey Garen
Comment 2
2011-05-16 00:08:29 PDT
rs=me to roll out that optimization with a layout test for /(|a)/.exec("a") /(a|)/.exec("b")
Gavin Barraclough
Comment 3
2011-05-16 02:08:37 PDT
Fixed in
r86547
.
Zoltan Herczeg
Comment 4
2011-05-18 06:24:45 PDT
Perhaps a non-greedy conversion? (|a) == a?? (a|) == a?
Gavin Barraclough
Comment 5
2011-05-23 13:51:01 PDT
Conversion to an appropriately greedy quantifier would be possible, but would limit the scope of this optimization. We would consider such a patch if it were to provide a useful performance gain on an interesting workload.
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug