Page MenuHomeFreeBSD

regex(3): Refactor fast/slow stepping bits in the matching engine
ClosedPublic

Authored by kevans on Jun 16 2017, 3:00 AM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Dec 31, 4:40 PM
Unknown Object (File)
Nov 29 2024, 8:24 PM
Unknown Object (File)
Nov 16 2024, 10:01 AM
Unknown Object (File)
Nov 12 2024, 9:21 PM
Unknown Object (File)
Oct 1 2024, 3:02 AM
Unknown Object (File)
Sep 30 2024, 5:19 PM
Unknown Object (File)
Sep 27 2024, 2:50 PM
Unknown Object (File)
Sep 27 2024, 3:10 AM
Subscribers
None

Details

Summary

Adding features for matching is fairly straightforward, but requires some
duplication because of this fast/slow setup. They can be fairly trivially combined
into a single walk(), so do it to make it less error prone.

Test Plan

Run regex(3), sed, grep, gsed tests

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 9976
Build 10406: arc lint + arc unit

Event Timeline

cem added inline comments.
lib/libc/regex/engine.c
868

style nit: spaces around +

This revision is now accepted and ready to land.Jun 17 2017, 7:29 PM
kevans edited edge metadata.
  • Address style nit
This revision now requires review to proceed.Jun 19 2017, 12:57 AM
This revision is now accepted and ready to land.Jun 19 2017, 4:52 PM
lib/libc/regex/engine.c
482

walk inside of assert() is OK?

lib/libc/regex/engine.c
482

I believe in this case it should be fine; it's a sanity walk that shouldn't alter state since we should have exhausted the substring at that point.

This revision was automatically updated to reflect the committed changes.