RE/flex is the fast lexical analyzer generator with full Unicode support, indent/nodent/dedent anchors, lazy quantifiers, word boundaries, and many other modern features. Supports Flex lexer specification syntax and is compatible with Bison/Yacc parsers. Generates reusable source code that is easy to understand. Supports fast scanning of UTF-8/16/32 files, strings, and streams. The reflex scanner generator tool generates clean lexer class code that is thread-safe. Generates Graphviz files to visualize state machine DFAs. RE/flex also offers a collection of class templates to wrap C++ regex engines in a unified API for scanning and searching large data sources.
1.4.005 Sep 2019 06:05
Added reflex option -S (--find) for efficient searching instead of scanning input (i.e. efficiently ignoring unmatched input) demonstrated with new findfast and findsearch examples, changed --nodefault to throw an exception when option --flex is not used and when the default rule is triggered.
1.3.614 Aug 2019 15:05
Added lexer and matcher buffer(base, size) methods and improved Flex-compatible yy_scan_buffer(base, size), these functions scan memory fast with zero copy overhead, added mmap.l example to scan an mmap-ed file fast with mmap(2) and buffer(base, size), other improvements.
1.3.229 Jul 2019 03:15
Added defined name expansion in bracket lists for the union , intersection amp; amp;, and subtraction -- operations.
1.3.125 Jul 2019 21:24
Added subtractive start condition scoping with ``, added undent ` k` anchor to undo indenting changes ("undenting") with an example in `examples/indent2.l`, improved indent ` i` and dedent ` j` anchors and other improvements.
Added `matcher().tabs(n)` to set tab size, used by `columno()` and indent ` i` and dedent ` j` anchors, new `reflex::Pattern` methods, other improvements.