-s ::= ws grammar ws => "gram"
-ws !::= w**
-wp !::= 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"
-psy ::= ps
- | ps wp ^"/" ws e
-psx ::= psy ^"?=>" e /ws
- | psy ^"!=>" e /ws
- > psy
-sequence ::= quoted => "qprod"
- > 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 ^"+/" e /ws)
- | (e ^"**" /ws > e ^"*" /ws)
- | (e ^"**/" e /ws > e ^"*/" e /ws)
- | e ^"?" /ws
-
- | "(" word ^")" /ws
- > ^"(" alternatives ")" /ws
-w !::= " "
- | "//" ([~\n]*) "\n"
- | "\n"
- | "\r"
+s ::= !ws 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
+NamedElements ::= (e | word ^":" e) */ ws
+
+PreSequence ::= NamedElements => "ps"
+ | PreSequence !wp ^"/" !ws e
+ | PreSequence ^"->" e /ws
+ | PreSequence ^"=>" ("[]"|"()"|word|Quoted) /ws
+Sequence ::= PreSequence => "psx"
+
+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
+ | ^"^" Quoted /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++