• Jakob Gruber's avatar
    [regexp] Rewrite certain Assertion sequences · c51e4f3c
    Jakob Gruber authored
    RegExp assertions (e.g.: '^', '$', '\b', ...) sequences have certain
    properties that this rewriter exploits:
    
    1. They are zero-width and order-independent, thus one can remove all
    duplicate assertions.
    2. If a subsequence is guaranteed to fail, the entire sequence fails.
    Any sequence always known to fail (e.g. containing both '\b' and '\B')
    can be rewritten to a single node that triggers failure.
    
    This CL generalizes the previous optimization for repeated assertions
    to be order-independent, i.e. assertions only have to be in the same
    sequence but not next to each other.
    
    Bug: v8:6515, v8:6126
    Change-Id: I3f92f081ce8a55ad8c34c269a09a6686e3b008f3
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1657925
    Commit-Queue: Jakob Gruber <jgruber@chromium.org>
    Reviewed-by: 's avatarPeter Marshall <petermarshall@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#62201}
    c51e4f3c
Name
Last commit
Last update
benchmarks Loading commit data...
build_overrides Loading commit data...
custom_deps Loading commit data...
docs Loading commit data...
gni Loading commit data...
include Loading commit data...
infra Loading commit data...
samples Loading commit data...
src Loading commit data...
test Loading commit data...
testing Loading commit data...
third_party Loading commit data...
tools Loading commit data...
.clang-format Loading commit data...
.clang-tidy Loading commit data...
.editorconfig Loading commit data...
.git-blame-ignore-revs Loading commit data...
.gitattributes Loading commit data...
.gitignore Loading commit data...
.gn Loading commit data...
.vpython Loading commit data...
.ycm_extra_conf.py Loading commit data...
AUTHORS Loading commit data...
BUILD.gn Loading commit data...
CODE_OF_CONDUCT.md Loading commit data...
COMMON_OWNERS Loading commit data...
ChangeLog Loading commit data...
DEPS Loading commit data...
ENG_REVIEW_OWNERS Loading commit data...
INFRA_OWNERS Loading commit data...
INTL_OWNERS Loading commit data...
LICENSE Loading commit data...
LICENSE.fdlibm Loading commit data...
LICENSE.strongtalk Loading commit data...
LICENSE.v8 Loading commit data...
LICENSE.valgrind Loading commit data...
MIPS_OWNERS Loading commit data...
OWNERS Loading commit data...
PPC_OWNERS Loading commit data...
PRESUBMIT.py Loading commit data...
README.md Loading commit data...
S390_OWNERS Loading commit data...
WATCHLISTS Loading commit data...
codereview.settings Loading commit data...