-s ::= ws grammar ws => "gram"
-ws !::= w**
-grammar ::= r +/ ws => "grammar"
-
-r ::= word ^"::=" alternatives /ws
- | word ^"!::=" alternatives /ws
-
-alternatives ::= (conjuncts +/ (ws "|" ws)) +/ (ws ">" ws)
-
-conjuncts ::= sequence
- | sequence ^"&" e*/ws /ws
- | sequence ^"&~" e*/ws /ws
-
-ps ::= e*/ws => "ps"
- | (e+/ws ws)? "^" quoted (ws e+/ws)? => "ps2"
-psx ::= ps
- > ps ^"/" e /ws
-sequence ::= psx
- | psx ^"=>" (word|quoted) /ws
-
-ec ::= [~\-\]\\\~]
- | escaped
-
-range ::= ec => "range"
- | ec ^"-" ec
-
-e ::= word => "nonTerminal"
- | quoted => "literal"
- | ^"()"
- | ^"{" sequence "}" /ws
- | ^"[" range* "]"
- | ^"[~" range* "]"
-
- | (e ws ^"**" > e ws ^"*")
- | e ^"*/" e /ws
- | (e ws ^"++" > e ws ^"+")
- | e ^"+/" e /ws
- | e ^"?" /ws
-
- | "(" word ^")" /ws
- > ^"(" alternatives ")" /ws
-w !::= " "
- | "//" ([~\n]*) "\n"
- | "\n"
- | "\r"
+s ::= Grammar ws => "gram"
+Grammar ::= NonTerminal +/ ws => "grammar"
+NonTerminal ::= word ^"::=" RHS /ws
+
+RHS ::= (Conjuncts +/ (!ws "|" !ws)) +/ (!ws ">" !ws)
+
+Conjuncts ::= Sequence
+ | Sequence ^"&" Elements /ws
+ | Sequence ^"&~" Elements /ws
+Elements ::= e*/ws
+
+ps ::= Elements => "ps"
+ | (e+/ws !ws)? ^"^" Quoted (!ws e+/ws)?
+psy ::= ps
+ | ps !wp ^"/" !ws e
+psx ::= psy => "psy"
+ | psy ^"->" e /ws
+Sequence ::= Quoted => "qprod"
+ > psx => "psx"
+ | psx "=>" ^"[]" /ws
+ | psx ^"=>" ("()"|word|Quoted) /ws
+
+ec ::= ~[\-\]\\]
+ | escaped
+
+Range ::= ec => "range"
+ | ec ^"-" ec
+
+e ::= word => "nonTerminal"
+ | Quoted => "literal"
+ | ^"()"
+ | ^"{" Sequence "}" /ws
+ | ^"[" Range* "]"
+
+ | e ^"++" /ws -> ~[/]
+ | e ^"+" /ws -> ~[+]
+ | e ^"++/" e /ws
+ | e ^"+/" e /ws
+ | e ^"**" /ws -> ~[/]
+ | e ^"*" /ws -> ~[*]
+ | e ^"**/" e /ws
+ | e ^"*/" e /ws
+ | ^"!" e /ws
+ | e ^"?" /ws
+
+ | "(" word ^")" /ws
+ > ^"(" RHS ")" /ws
+ | ^"~" e
+
word ::= [a-zA-Z0-9_]++
-quoted ::= "\"" (([~\"\\] | escaped)+) "\""
+Quoted ::= "\"" ((~[\"\\] | escaped)+) "\""
| "\"\"" => ""
escaped ::= "\\n" => "\n"
| "\\r" => "\r"
- | "\\" [~nr]
+ | "\\" ~[nr]
+w ::= " " | "\n" | "\r"
+ws ::= w** => ()
+ | w** "//" ~[\n]* "\n" ws => ()
+wp ::= w++