4.7 BNF Grammars
The scribble/bnf library
provides utilities for typesetting grammars.
For example,
@(let ([open @litchar{(}] |
[close @litchar{)}]) |
@BNF[(list @nonterm{expr} |
@nonterm{id} |
@BNF-seq[open @kleeneplus[@nonterm{expr}] close] |
@BNF-seq[open @litchar{lambda} |
open @kleenestar[@nonterm{id}] close |
@nonterm{expr} close] |
@nonterm{val}) |
(list @nonterm{val} |
@BNF-alt[@nonterm{number} @nonterm{primop}]) |
(list @nonterm{id} |
@elem{any name except for @litchar{lambda}})]) |
produces the output
| ‹expr› | ::= | ‹id› |
|
| | | ( ‹expr›+ ) |
|
| | | ( lambda ( ‹id›* ) ‹expr› ) |
|
| | | ‹val› |
| ‹val› | ::= | ‹number› | ‹primop› |
| ‹id› | ::= | any name except for lambda |
See also racketgrammar.
Typesets a grammar table. Each production starts with an element
(typically constructed with nonterm) for the non-terminal
being defined, and then a list of possibilities (typically constructed
with BNF-seq, etc.) to show on separate lines.
Typesets a non-terminal: italic in angle brackets.
Typesets a sequence.
Typesets a group surrounded by curly braces (so the entire group can
be repeated, for example).
Typesets an optional element: in square brackets.
(kleenestar pre-content ...) → element? |
pre-content : any/c |
Typesets a 0-or-more repetition.
(kleeneplus pre-content ...) → element? |
pre-content : any/c |
Typesets a 1-or-more repetition.
(kleenerange n m pre-content ...) → element? |
n : any/c |
m : any/c |
pre-content : any/c |
Typesets a n-to-m repetition. The n and
m arguments are converted to a string using (format "~a" n) and (format "~a" m).
Typesets alternatives for a production’s right-hand side to appear on
a single line. The result is normally used as a single possibility in
a production list for BNF.
A string to use for omitted productions or content.