RE/flex & Bison
The RE/flex and Bison tools are modern tools but have antecedents,
- RE/flex is based on Lex:
The original paper on Lex:
- Lesk, M. E. and E. Schmidt [1975].
Lex: A Lexical Analyzer Generator. Computing Science Technical Report No. 39, Bell Laboratories, Murray Hill, New Jersey.
- Bison is based on Yacc, here is the original Yacc paper:
- Johnson, Stephen C. [1975].
Yacc: Yet Another Compiler Compiler. Computing Science Technical Report No. 32, Bell Laboratories, Murray hill, New Jersey.
- Bison documentation:
The Bison documentation,
- RE/flex
RE/flex is a C++ library that serves as a replacement for the popular Flex lexer generator.
It provides similar functionalities to Flex, with the added benefits of being written in C++, which results in improved performance and advanced features.
- Key features:
Generation of deterministic and non-deterministic finite automata
Support for Unicode, wide characters, and multiple character sets
- Compatibility with Flex:
RE/flex is compatible with the input and output formats used by Flex, allowing for easy migration of existing Flex-based projects to RE/flex.
RE/flex offers a more powerful and flexible alternative to Flex, while still maintaining compatibility with its input and output formats.
This allows developers to take advantage of RE/flex’s improved performance and advanced features, while still being able to work with familiar formats and tools.
- Reflex documentation:
RE/flex documentation is available for browsing.
- How to start with Lex and Yacc:
These introductory guides can help beginners:
- Thomas Niemann.
A Compact Guide to Lex & Yacc. An introduction to Lex and Yacc.
- Collective Work
Programming with GNU Software. Contains information about Autoconf, Automake, Gperf, Flex, Bison, and GCC.