wand/iniparser.gen.go

1051 lines
30 KiB
Go
Raw Normal View History

/*
This file was generated with treerack (https://code.squareroundforest.org/arpio/treerack).
The contents of this file fall under different licenses.
The code between the "// head" and "// eo head" lines falls under the same
license as the source code of treerack (https://code.squareroundforest.org/arpio/treerack),
unless explicitly stated otherwise, if treerack's license allows changing the
license of this source code.
Treerack's license: MIT https://opensource.org/licenses/MIT
where YEAR=2017, COPYRIGHT HOLDER=Arpad Ryszka (arpad.ryszka@gmail.com)
The rest of the content of this file falls under the same license as the one
that the user of treerack generating this file declares for it, or it is
unlicensed.
*/
package wand
// head
import (
"bufio"
"errors"
"fmt"
"io"
"strconv"
"strings"
"unicode"
)
type charParser struct {
name string
id int
not bool
chars []rune
ranges [][]rune
}
type charBuilder struct {
name string
id int
}
func (p *charParser) nodeName() string {
return p.name
}
func (p *charParser) nodeID() int {
return p.id
}
func (p *charParser) commitType() commitType {
return alias
}
func matchChar(chars []rune, ranges [][]rune, not bool, char rune) bool {
for _, ci := range chars {
if ci == char {
return !not
}
}
for _, ri := range ranges {
if char >= ri[0] && char <= ri[1] {
return !not
}
}
return not
}
func (p *charParser) match(t rune) bool {
return matchChar(p.chars, p.ranges, p.not, t)
}
func (p *charParser) parse(c *context) {
if tok, ok := c.token(); !ok || !p.match(tok) {
if c.offset > c.failOffset {
c.failOffset = c.offset
c.failingParser = nil
}
c.fail(c.offset)
return
}
c.success(c.offset + 1)
}
func (b *charBuilder) nodeName() string {
return b.name
}
func (b *charBuilder) nodeID() int {
return b.id
}
func (b *charBuilder) build(c *context) ([]*node, bool) {
return nil, false
}
type sequenceParser struct {
name string
id int
commit commitType
items []parser
ranges [][]int
generalizations []int
allChars bool
}
type sequenceBuilder struct {
name string
id int
commit commitType
items []builder
ranges [][]int
generalizations []int
allChars bool
}
func (p *sequenceParser) nodeName() string {
return p.name
}
func (p *sequenceParser) nodeID() int {
return p.id
}
func (p *sequenceParser) commitType() commitType {
return p.commit
}
func (p *sequenceParser) parse(c *context) {
if !p.allChars {
if c.results.pending(c.offset, p.id) {
c.fail(c.offset)
return
}
c.results.markPending(c.offset, p.id)
}
var (
currentCount int
parsed bool
)
itemIndex := 0
from := c.offset
to := c.offset
for itemIndex < len(p.items) {
p.items[itemIndex].parse(c)
if !c.matchLast {
if currentCount >= p.ranges[itemIndex][0] {
itemIndex++
currentCount = 0
continue
}
c.offset = from
if c.fromResults(p) {
if to > c.failOffset {
c.failOffset = -1
c.failingParser = nil
}
if !p.allChars {
c.results.unmarkPending(from, p.id)
}
return
}
if c.failingParser == nil && p.commit&userDefined != 0 && p.commit&whitespace == 0 && p.commit&failPass == 0 {
c.failingParser = p
}
c.fail(from)
if !p.allChars {
c.results.unmarkPending(from, p.id)
}
return
}
parsed = c.offset > to
if parsed {
currentCount++
}
to = c.offset
if !parsed || p.ranges[itemIndex][1] > 0 && currentCount == p.ranges[itemIndex][1] {
itemIndex++
currentCount = 0
}
}
if p.commit&noKeyword != 0 && c.isKeyword(from, to) {
if c.failingParser == nil && p.commit&userDefined != 0 && p.commit&whitespace == 0 && p.commit&failPass == 0 {
c.failingParser = p
}
c.fail(from)
if !p.allChars {
c.results.unmarkPending(from, p.id)
}
return
}
for _, g := range p.generalizations {
if c.results.pending(from, g) {
c.results.setMatch(from, g, to)
}
}
if to > c.failOffset {
c.failOffset = -1
c.failingParser = nil
}
c.results.setMatch(from, p.id, to)
c.success(to)
if !p.allChars {
c.results.unmarkPending(from, p.id)
}
}
func (b *sequenceBuilder) nodeName() string {
return b.name
}
func (b *sequenceBuilder) nodeID() int {
return b.id
}
func (b *sequenceBuilder) build(c *context) ([]*node, bool) {
to, ok := c.results.longestMatch(c.offset, b.id)
if !ok {
return nil, false
}
from := c.offset
parsed := to > from
if b.allChars {
c.offset = to
if b.commit&alias != 0 {
return nil, true
}
return []*node{{Name: b.name, From: from, To: to, tokens: c.tokens}}, true
} else if parsed {
c.results.dropMatchTo(c.offset, b.id, to)
for _, g := range b.generalizations {
c.results.dropMatchTo(c.offset, g, to)
}
} else {
if c.results.pending(c.offset, b.id) {
return nil, false
}
c.results.markPending(c.offset, b.id)
for _, g := range b.generalizations {
c.results.markPending(c.offset, g)
}
}
var (
itemIndex int
currentCount int
nodes []*node
)
for itemIndex < len(b.items) {
itemFrom := c.offset
n, ok := b.items[itemIndex].build(c)
if !ok {
itemIndex++
currentCount = 0
continue
}
if c.offset > itemFrom {
nodes = append(nodes, n...)
currentCount++
if b.ranges[itemIndex][1] > 0 && currentCount == b.ranges[itemIndex][1] {
itemIndex++
currentCount = 0
}
continue
}
if currentCount < b.ranges[itemIndex][0] {
for i := 0; i < b.ranges[itemIndex][0]-currentCount; i++ {
nodes = append(nodes, n...)
}
}
itemIndex++
currentCount = 0
}
if !parsed {
c.results.unmarkPending(from, b.id)
for _, g := range b.generalizations {
c.results.unmarkPending(from, g)
}
}
if b.commit&alias != 0 {
return nodes, true
}
return []*node{{Name: b.name, From: from, To: to, Nodes: nodes, tokens: c.tokens}}, true
}
type choiceParser struct {
name string
id int
commit commitType
options []parser
generalizations []int
}
type choiceBuilder struct {
name string
id int
commit commitType
options []builder
generalizations []int
}
func (p *choiceParser) nodeName() string {
return p.name
}
func (p *choiceParser) nodeID() int {
return p.id
}
func (p *choiceParser) commitType() commitType {
return p.commit
}
func (p *choiceParser) parse(c *context) {
if c.fromResults(p) {
return
}
if c.results.pending(c.offset, p.id) {
c.fail(c.offset)
return
}
c.results.markPending(c.offset, p.id)
var (
match bool
optionIndex int
foundMatch bool
failingParser parser
)
from := c.offset
to := c.offset
initialFailOffset := c.failOffset
initialFailingParser := c.failingParser
failOffset := initialFailOffset
for {
foundMatch = false
optionIndex = 0
for optionIndex < len(p.options) {
p.options[optionIndex].parse(c)
optionIndex++
if !c.matchLast {
if c.failOffset > failOffset {
failOffset = c.failOffset
failingParser = c.failingParser
}
}
if !c.matchLast || match && c.offset <= to {
c.offset = from
continue
}
match = true
foundMatch = true
to = c.offset
c.offset = from
c.results.setMatch(from, p.id, to)
}
if !foundMatch {
break
}
}
if match {
if p.commit&noKeyword != 0 && c.isKeyword(from, to) {
if c.failingParser == nil && p.commit&userDefined != 0 && p.commit&whitespace == 0 && p.commit&failPass == 0 {
c.failingParser = p
}
c.fail(from)
c.results.unmarkPending(from, p.id)
return
}
if failOffset > to {
c.failOffset = failOffset
c.failingParser = failingParser
} else if to > initialFailOffset {
c.failOffset = -1
c.failingParser = nil
} else {
c.failOffset = initialFailOffset
c.failingParser = initialFailingParser
}
c.success(to)
c.results.unmarkPending(from, p.id)
return
}
if failOffset > initialFailOffset {
c.failOffset = failOffset
c.failingParser = failingParser
if c.failingParser == nil && p.commitType()&userDefined != 0 && p.commitType()&whitespace == 0 && p.commitType()&failPass == 0 {
c.failingParser = p
}
}
c.results.setNoMatch(from, p.id)
c.fail(from)
c.results.unmarkPending(from, p.id)
}
func (b *choiceBuilder) nodeName() string {
return b.name
}
func (b *choiceBuilder) nodeID() int {
return b.id
}
func (b *choiceBuilder) build(c *context) ([]*node, bool) {
to, ok := c.results.longestMatch(c.offset, b.id)
if !ok {
return nil, false
}
from := c.offset
parsed := to > from
if parsed {
c.results.dropMatchTo(c.offset, b.id, to)
for _, g := range b.generalizations {
c.results.dropMatchTo(c.offset, g, to)
}
} else {
if c.results.pending(c.offset, b.id) {
return nil, false
}
c.results.markPending(c.offset, b.id)
for _, g := range b.generalizations {
c.results.markPending(c.offset, g)
}
}
var option builder
for _, o := range b.options {
if c.results.hasMatchTo(c.offset, o.nodeID(), to) {
option = o
break
}
}
n, _ := option.build(c)
if !parsed {
c.results.unmarkPending(from, b.id)
for _, g := range b.generalizations {
c.results.unmarkPending(from, g)
}
}
if b.commit&alias != 0 {
return n, true
}
return []*node{{Name: b.name, From: from, To: to, Nodes: n, tokens: c.tokens}}, true
}
type idSet struct{ ids []uint }
func divModBits(id int) (int, int) {
return id / strconv.IntSize, id % strconv.IntSize
}
func (s *idSet) set(id int) {
d, m := divModBits(id)
if d >= len(s.ids) {
if d < cap(s.ids) {
s.ids = s.ids[:d+1]
} else {
s.ids = s.ids[:cap(s.ids)]
for i := cap(s.ids); i <= d; i++ {
s.ids = append(s.ids, 0)
}
}
}
s.ids[d] |= 1 << uint(m)
}
func (s *idSet) unset(id int) {
d, m := divModBits(id)
if d >= len(s.ids) {
return
}
s.ids[d] &^= 1 << uint(m)
}
func (s *idSet) has(id int) bool {
d, m := divModBits(id)
if d >= len(s.ids) {
return false
}
return s.ids[d]&(1<<uint(m)) != 0
}
type results struct {
noMatch []*idSet
match [][]int
isPending [][]int
}
func ensureOffsetInts(ints [][]int, offset int) [][]int {
if len(ints) > offset {
return ints
}
if cap(ints) > offset {
ints = ints[:offset+1]
return ints
}
ints = ints[:cap(ints)]
for i := len(ints); i <= offset; i++ {
ints = append(ints, nil)
}
return ints
}
func ensureOffsetIDs(ids []*idSet, offset int) []*idSet {
if len(ids) > offset {
return ids
}
if cap(ids) > offset {
ids = ids[:offset+1]
return ids
}
ids = ids[:cap(ids)]
for i := len(ids); i <= offset; i++ {
ids = append(ids, nil)
}
return ids
}
func (r *results) setMatch(offset, id, to int) {
r.match = ensureOffsetInts(r.match, offset)
for i := 0; i < len(r.match[offset]); i += 2 {
if r.match[offset][i] != id || r.match[offset][i+1] != to {
continue
}
return
}
r.match[offset] = append(r.match[offset], id, to)
}
func (r *results) setNoMatch(offset, id int) {
if len(r.match) > offset {
for i := 0; i < len(r.match[offset]); i += 2 {
if r.match[offset][i] != id {
continue
}
return
}
}
r.noMatch = ensureOffsetIDs(r.noMatch, offset)
if r.noMatch[offset] == nil {
r.noMatch[offset] = &idSet{}
}
r.noMatch[offset].set(id)
}
func (r *results) hasMatchTo(offset, id, to int) bool {
if len(r.match) <= offset {
return false
}
for i := 0; i < len(r.match[offset]); i += 2 {
if r.match[offset][i] != id {
continue
}
if r.match[offset][i+1] == to {
return true
}
}
return false
}
func (r *results) longestMatch(offset, id int) (int, bool) {
if len(r.match) <= offset {
return 0, false
}
var found bool
to := -1
for i := 0; i < len(r.match[offset]); i += 2 {
if r.match[offset][i] != id {
continue
}
if r.match[offset][i+1] > to {
to = r.match[offset][i+1]
}
found = true
}
return to, found
}
func (r *results) longestResult(offset, id int) (int, bool, bool) {
if len(r.noMatch) > offset && r.noMatch[offset] != nil && r.noMatch[offset].has(id) {
return 0, false, true
}
to, ok := r.longestMatch(offset, id)
return to, ok, ok
}
func (r *results) dropMatchTo(offset, id, to int) {
for i := 0; i < len(r.match[offset]); i += 2 {
if r.match[offset][i] != id {
continue
}
if r.match[offset][i+1] == to {
r.match[offset][i] = -1
return
}
}
}
func (r *results) resetPending() {
r.isPending = nil
}
func (r *results) pending(offset, id int) bool {
if len(r.isPending) <= id {
return false
}
for i := range r.isPending[id] {
if r.isPending[id][i] == offset {
return true
}
}
return false
}
func (r *results) markPending(offset, id int) {
r.isPending = ensureOffsetInts(r.isPending, id)
for i := range r.isPending[id] {
if r.isPending[id][i] == -1 {
r.isPending[id][i] = offset
return
}
}
r.isPending[id] = append(r.isPending[id], offset)
}
func (r *results) unmarkPending(offset, id int) {
for i := range r.isPending[id] {
if r.isPending[id][i] == offset {
r.isPending[id][i] = -1
break
}
}
}
type context struct {
reader io.RuneReader
keywords []parser
offset int
readOffset int
consumed int
offsetLimit int
failOffset int
failingParser parser
readErr error
eof bool
results *results
tokens []rune
matchLast bool
}
func newContext(r io.RuneReader, keywords []parser) *context {
return &context{reader: r, keywords: keywords, results: &results{}, offsetLimit: -1, failOffset: -1}
}
func (c *context) read() bool {
if c.eof || c.readErr != nil {
return false
}
token, n, err := c.reader.ReadRune()
if err != nil {
if err == io.EOF {
if n == 0 {
c.eof = true
return false
}
} else {
c.readErr = err
return false
}
}
c.readOffset++
if token == unicode.ReplacementChar {
c.readErr = errInvalidUnicodeCharacter
return false
}
c.tokens = append(c.tokens, token)
return true
}
func (c *context) token() (rune, bool) {
if c.offset == c.offsetLimit {
return 0, false
}
if c.offset == c.readOffset {
if !c.read() {
return 0, false
}
}
return c.tokens[c.offset], true
}
func (c *context) fromResults(p parser) bool {
to, m, ok := c.results.longestResult(c.offset, p.nodeID())
if !ok {
return false
}
if m {
c.success(to)
} else {
c.fail(c.offset)
}
return true
}
func (c *context) isKeyword(from, to int) bool {
ol := c.offsetLimit
c.offsetLimit = to
defer func() {
c.offsetLimit = ol
}()
for _, kw := range c.keywords {
c.offset = from
kw.parse(c)
if c.matchLast && c.offset == to {
return true
}
}
return false
}
func (c *context) success(to int) {
c.offset = to
c.matchLast = true
if to > c.consumed {
c.consumed = to
}
}
func (c *context) fail(offset int) {
c.offset = offset
c.matchLast = false
}
func findLine(tokens []rune, offset int) (line, column int) {
tokens = tokens[:offset]
for i := range tokens {
column++
if tokens[i] == '\n' {
column = 0
line++
}
}
return
}
func (c *context) parseError(p parser) error {
definition := p.nodeName()
flagIndex := strings.Index(definition, ":")
if flagIndex > 0 {
definition = definition[:flagIndex]
}
if c.failingParser == nil {
c.failOffset = c.consumed
}
line, col := findLine(c.tokens, c.failOffset)
return &parseError{Offset: c.failOffset, Line: line, Column: col, Definition: definition}
}
func (c *context) finalizeParse(root parser) error {
fp := c.failingParser
if fp == nil {
fp = root
}
to, match, found := c.results.longestResult(0, root.nodeID())
if !found || !match || found && match && to < c.readOffset {
return c.parseError(fp)
}
c.read()
if c.eof {
return nil
}
if c.readErr != nil {
return c.readErr
}
return c.parseError(root)
}
type node struct {
Name string
Nodes []*node
From, To int
tokens []rune
}
func (n *node) Tokens() []rune {
return n.tokens
}
func (n *node) String() string {
return fmt.Sprintf("%s:%d:%d:%s", n.Name, n.From, n.To, n.Text())
}
func (n *node) Text() string {
return string(n.Tokens()[n.From:n.To])
}
type commitType int
const (
none commitType = 0
alias commitType = 1 << iota
whitespace
noWhitespace
keyword
noKeyword
failPass
root
userDefined
)
type formatFlags int
const (
formatNone formatFlags = 0
formatPretty formatFlags = 1 << iota
formatIncludeComments
)
type parseError struct {
Input string
Offset int
Line int
Column int
Definition string
}
type parser interface {
nodeName() string
nodeID() int
commitType() commitType
parse(*context)
}
type builder interface {
nodeName() string
nodeID() int
build(*context) ([]*node, bool)
}
var errInvalidUnicodeCharacter = errors.New("invalid unicode character")
func (pe *parseError) Error() string {
return fmt.Sprintf("%s:%d:%d:parse failed, parsing: %s", pe.Input, pe.Line+1, pe.Column+1, pe.Definition)
}
func parseInput(r io.Reader, p parser, b builder, kw []parser) (*node, error) {
c := newContext(bufio.NewReader(r), kw)
p.parse(c)
if c.readErr != nil {
return nil, c.readErr
}
if err := c.finalizeParse(p); err != nil {
if perr, ok := err.(*parseError); ok {
perr.Input = "<input>"
}
return nil, err
}
c.offset = 0
c.results.resetPending()
n, _ := b.build(c)
return n[0], nil
}
// eo head
func parse(r io.Reader) (*node, error) {
var p67 = sequenceParser{id: 67, commit: 128, ranges: [][]int{{0, -1}, {1, 1}, {0, -1}}}
var p65 = choiceParser{id: 65, commit: 2}
var p64 = sequenceParser{id: 64, commit: 262, name: "whitespace", allChars: true, ranges: [][]int{{1, 1}, {1, 1}}, generalizations: []int{65}}
var p1 = charParser{id: 1, chars: []rune{32, 8, 12, 13, 9, 11}}
p64.items = []parser{&p1}
p65.options = []parser{&p64}
var p66 = sequenceParser{id: 66, commit: 258, name: "doc:wsroot", ranges: [][]int{{0, 1}}}
var p63 = sequenceParser{id: 63, commit: 2, ranges: [][]int{{1, 1}, {0, -1}}}
var p61 = choiceParser{id: 61, commit: 2}
var p58 = sequenceParser{id: 58, commit: 256, name: "key-val", ranges: [][]int{{0, 1}, {0, -1}, {1, 1}, {0, -1}, {0, 1}, {0, -1}, {0, 1}}, generalizations: []int{61}}
var p54 = sequenceParser{id: 54, commit: 2, ranges: [][]int{{1, 1}, {0, -1}, {1, 1}}}
var p14 = sequenceParser{id: 14, commit: 256, name: "comment", ranges: [][]int{{1, 1}, {0, 1}}}
var p8 = sequenceParser{id: 8, commit: 258, name: "comment-line", ranges: [][]int{{1, 1}, {0, 1}}, generalizations: []int{61}}
var p3 = sequenceParser{id: 3, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var p2 = charParser{id: 2, chars: []rune{35}}
p3.items = []parser{&p2}
var p7 = sequenceParser{id: 7, commit: 2, ranges: [][]int{{0, -1}, {1, 1}, {0, -1}}}
var p5 = sequenceParser{id: 5, commit: 2, allChars: true, ranges: [][]int{{1, 1}}}
var p4 = charParser{id: 4, not: true, chars: []rune{10}}
p5.items = []parser{&p4}
var p6 = sequenceParser{id: 6, commit: 2, ranges: [][]int{{0, -1}, {1, 1}}}
p6.items = []parser{&p65, &p5}
p7.items = []parser{&p65, &p5, &p6}
p8.items = []parser{&p3, &p7}
var p13 = sequenceParser{id: 13, commit: 2, ranges: [][]int{{0, -1}, {1, 1}, {0, -1}}}
var p11 = sequenceParser{id: 11, commit: 2, ranges: [][]int{{1, 1}, {0, -1}, {1, 1}}}
var p10 = sequenceParser{id: 10, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var p9 = charParser{id: 9, chars: []rune{10}}
p10.items = []parser{&p9}
p11.items = []parser{&p10, &p65, &p8}
var p12 = sequenceParser{id: 12, commit: 2, ranges: [][]int{{0, -1}, {1, 1}}}
p12.items = []parser{&p65, &p11}
p13.items = []parser{&p65, &p11, &p12}
p14.items = []parser{&p8, &p13}
var p53 = sequenceParser{id: 53, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var p52 = charParser{id: 52, chars: []rune{10}}
p53.items = []parser{&p52}
p54.items = []parser{&p14, &p65, &p53}
var p39 = choiceParser{id: 39, commit: 256, name: "key"}
var p38 = sequenceParser{id: 38, commit: 266, name: "word", ranges: [][]int{{1, 1}, {0, -1}, {1, 1}, {0, -1}}, generalizations: []int{39}}
var p29 = sequenceParser{id: 29, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var p28 = charParser{id: 28, chars: []rune{95}, ranges: [][]rune{{97, 122}, {65, 90}}}
p29.items = []parser{&p28}
var p37 = choiceParser{id: 37, commit: 10}
var p31 = sequenceParser{id: 31, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}, generalizations: []int{37}}
var p30 = charParser{id: 30, chars: []rune{95, 45}, ranges: [][]rune{{97, 122}, {65, 90}, {48, 57}}}
p31.items = []parser{&p30}
var p36 = sequenceParser{id: 36, commit: 10, ranges: [][]int{{1, 1}, {1, 1}, {1, 1}, {1, 1}}, generalizations: []int{37}}
var p33 = sequenceParser{id: 33, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var p32 = charParser{id: 32, chars: []rune{92}}
p33.items = []parser{&p32}
var p35 = sequenceParser{id: 35, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var p34 = charParser{id: 34, not: true}
p35.items = []parser{&p34}
p36.items = []parser{&p33, &p35}
p37.options = []parser{&p31, &p36}
p38.items = []parser{&p29, &p37}
var p27 = sequenceParser{id: 27, commit: 266, name: "quoted", ranges: [][]int{{1, 1}, {0, -1}, {1, 1}, {1, 1}, {0, -1}, {1, 1}}, generalizations: []int{39, 51}}
var p16 = sequenceParser{id: 16, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var p15 = charParser{id: 15, chars: []rune{34}}
p16.items = []parser{&p15}
var p24 = choiceParser{id: 24, commit: 10}
var p18 = sequenceParser{id: 18, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}, generalizations: []int{24}}
var p17 = charParser{id: 17, not: true, chars: []rune{92, 34}}
p18.items = []parser{&p17}
var p23 = sequenceParser{id: 23, commit: 10, ranges: [][]int{{1, 1}, {1, 1}, {1, 1}, {1, 1}}, generalizations: []int{24}}
var p20 = sequenceParser{id: 20, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var p19 = charParser{id: 19, chars: []rune{92}}
p20.items = []parser{&p19}
var p22 = sequenceParser{id: 22, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var p21 = charParser{id: 21, not: true}
p22.items = []parser{&p21}
p23.items = []parser{&p20, &p22}
p24.options = []parser{&p18, &p23}
var p26 = sequenceParser{id: 26, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var p25 = charParser{id: 25, chars: []rune{34}}
p26.items = []parser{&p25}
p27.items = []parser{&p16, &p24, &p26}
p39.options = []parser{&p38, &p27}
var p57 = sequenceParser{id: 57, commit: 2, ranges: [][]int{{1, 1}, {0, -1}, {0, 1}}}
var p56 = sequenceParser{id: 56, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var p55 = charParser{id: 55, chars: []rune{61}}
p56.items = []parser{&p55}
var p51 = choiceParser{id: 51, commit: 256, name: "value"}
var p50 = sequenceParser{id: 50, commit: 2, ranges: [][]int{{1, 1}, {0, -1}}, generalizations: []int{51}}
var p48 = sequenceParser{id: 48, commit: 266, name: "value-chars", ranges: [][]int{{1, -1}, {1, -1}}}
var p47 = choiceParser{id: 47, commit: 10}
var p41 = sequenceParser{id: 41, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}, generalizations: []int{47}}
var p40 = charParser{id: 40, not: true, chars: []rune{92, 34, 10, 61, 35, 32, 8, 12, 13, 9, 11}}
p41.items = []parser{&p40}
var p46 = sequenceParser{id: 46, commit: 10, ranges: [][]int{{1, 1}, {1, 1}, {1, 1}, {1, 1}}, generalizations: []int{47}}
var p43 = sequenceParser{id: 43, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var p42 = charParser{id: 42, chars: []rune{92}}
p43.items = []parser{&p42}
var p45 = sequenceParser{id: 45, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var p44 = charParser{id: 44, not: true}
p45.items = []parser{&p44}
p46.items = []parser{&p43, &p45}
p47.options = []parser{&p41, &p46}
p48.items = []parser{&p47}
var p49 = sequenceParser{id: 49, commit: 2, ranges: [][]int{{0, -1}, {1, 1}}}
p49.items = []parser{&p65, &p48}
p50.items = []parser{&p48, &p49}
p51.options = []parser{&p50, &p27}
p57.items = []parser{&p56, &p65, &p51}
p58.items = []parser{&p54, &p65, &p39, &p65, &p57, &p65, &p8}
var p60 = sequenceParser{id: 60, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}, generalizations: []int{61}}
var p59 = charParser{id: 59, chars: []rune{10}}
p60.items = []parser{&p59}
p61.options = []parser{&p58, &p8, &p60}
var p62 = sequenceParser{id: 62, commit: 2, ranges: [][]int{{0, -1}, {1, 1}}}
p62.items = []parser{&p65, &p61}
p63.items = []parser{&p61, &p62}
p66.items = []parser{&p63}
p67.items = []parser{&p65, &p66, &p65}
var b67 = sequenceBuilder{id: 67, commit: 128, name: "doc", ranges: [][]int{{0, -1}, {1, 1}, {0, -1}}}
var b65 = choiceBuilder{id: 65, commit: 2}
var b64 = sequenceBuilder{id: 64, commit: 262, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}, generalizations: []int{65}}
var b1 = charBuilder{}
b64.items = []builder{&b1}
b65.options = []builder{&b64}
var b66 = sequenceBuilder{id: 66, commit: 258, ranges: [][]int{{0, 1}}}
var b63 = sequenceBuilder{id: 63, commit: 2, ranges: [][]int{{1, 1}, {0, -1}}}
var b61 = choiceBuilder{id: 61, commit: 2}
var b58 = sequenceBuilder{id: 58, commit: 256, name: "key-val", ranges: [][]int{{0, 1}, {0, -1}, {1, 1}, {0, -1}, {0, 1}, {0, -1}, {0, 1}}, generalizations: []int{61}}
var b54 = sequenceBuilder{id: 54, commit: 2, ranges: [][]int{{1, 1}, {0, -1}, {1, 1}}}
var b14 = sequenceBuilder{id: 14, commit: 256, name: "comment", ranges: [][]int{{1, 1}, {0, 1}}}
var b8 = sequenceBuilder{id: 8, commit: 258, ranges: [][]int{{1, 1}, {0, 1}}, generalizations: []int{61}}
var b3 = sequenceBuilder{id: 3, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var b2 = charBuilder{}
b3.items = []builder{&b2}
var b7 = sequenceBuilder{id: 7, commit: 2, ranges: [][]int{{0, -1}, {1, 1}, {0, -1}}}
var b5 = sequenceBuilder{id: 5, commit: 2, allChars: true, ranges: [][]int{{1, 1}}}
var b4 = charBuilder{}
b5.items = []builder{&b4}
var b6 = sequenceBuilder{id: 6, commit: 2, ranges: [][]int{{0, -1}, {1, 1}}}
b6.items = []builder{&b65, &b5}
b7.items = []builder{&b65, &b5, &b6}
b8.items = []builder{&b3, &b7}
var b13 = sequenceBuilder{id: 13, commit: 2, ranges: [][]int{{0, -1}, {1, 1}, {0, -1}}}
var b11 = sequenceBuilder{id: 11, commit: 2, ranges: [][]int{{1, 1}, {0, -1}, {1, 1}}}
var b10 = sequenceBuilder{id: 10, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var b9 = charBuilder{}
b10.items = []builder{&b9}
b11.items = []builder{&b10, &b65, &b8}
var b12 = sequenceBuilder{id: 12, commit: 2, ranges: [][]int{{0, -1}, {1, 1}}}
b12.items = []builder{&b65, &b11}
b13.items = []builder{&b65, &b11, &b12}
b14.items = []builder{&b8, &b13}
var b53 = sequenceBuilder{id: 53, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var b52 = charBuilder{}
b53.items = []builder{&b52}
b54.items = []builder{&b14, &b65, &b53}
var b39 = choiceBuilder{id: 39, commit: 256, name: "key"}
var b38 = sequenceBuilder{id: 38, commit: 266, ranges: [][]int{{1, 1}, {0, -1}, {1, 1}, {0, -1}}, generalizations: []int{39}}
var b29 = sequenceBuilder{id: 29, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var b28 = charBuilder{}
b29.items = []builder{&b28}
var b37 = choiceBuilder{id: 37, commit: 10}
var b31 = sequenceBuilder{id: 31, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}, generalizations: []int{37}}
var b30 = charBuilder{}
b31.items = []builder{&b30}
var b36 = sequenceBuilder{id: 36, commit: 10, ranges: [][]int{{1, 1}, {1, 1}, {1, 1}, {1, 1}}, generalizations: []int{37}}
var b33 = sequenceBuilder{id: 33, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var b32 = charBuilder{}
b33.items = []builder{&b32}
var b35 = sequenceBuilder{id: 35, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var b34 = charBuilder{}
b35.items = []builder{&b34}
b36.items = []builder{&b33, &b35}
b37.options = []builder{&b31, &b36}
b38.items = []builder{&b29, &b37}
var b27 = sequenceBuilder{id: 27, commit: 266, ranges: [][]int{{1, 1}, {0, -1}, {1, 1}, {1, 1}, {0, -1}, {1, 1}}, generalizations: []int{39, 51}}
var b16 = sequenceBuilder{id: 16, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var b15 = charBuilder{}
b16.items = []builder{&b15}
var b24 = choiceBuilder{id: 24, commit: 10}
var b18 = sequenceBuilder{id: 18, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}, generalizations: []int{24}}
var b17 = charBuilder{}
b18.items = []builder{&b17}
var b23 = sequenceBuilder{id: 23, commit: 10, ranges: [][]int{{1, 1}, {1, 1}, {1, 1}, {1, 1}}, generalizations: []int{24}}
var b20 = sequenceBuilder{id: 20, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var b19 = charBuilder{}
b20.items = []builder{&b19}
var b22 = sequenceBuilder{id: 22, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var b21 = charBuilder{}
b22.items = []builder{&b21}
b23.items = []builder{&b20, &b22}
b24.options = []builder{&b18, &b23}
var b26 = sequenceBuilder{id: 26, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var b25 = charBuilder{}
b26.items = []builder{&b25}
b27.items = []builder{&b16, &b24, &b26}
b39.options = []builder{&b38, &b27}
var b57 = sequenceBuilder{id: 57, commit: 2, ranges: [][]int{{1, 1}, {0, -1}, {0, 1}}}
var b56 = sequenceBuilder{id: 56, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var b55 = charBuilder{}
b56.items = []builder{&b55}
var b51 = choiceBuilder{id: 51, commit: 256, name: "value"}
var b50 = sequenceBuilder{id: 50, commit: 2, ranges: [][]int{{1, 1}, {0, -1}}, generalizations: []int{51}}
var b48 = sequenceBuilder{id: 48, commit: 266, ranges: [][]int{{1, -1}, {1, -1}}}
var b47 = choiceBuilder{id: 47, commit: 10}
var b41 = sequenceBuilder{id: 41, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}, generalizations: []int{47}}
var b40 = charBuilder{}
b41.items = []builder{&b40}
var b46 = sequenceBuilder{id: 46, commit: 10, ranges: [][]int{{1, 1}, {1, 1}, {1, 1}, {1, 1}}, generalizations: []int{47}}
var b43 = sequenceBuilder{id: 43, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var b42 = charBuilder{}
b43.items = []builder{&b42}
var b45 = sequenceBuilder{id: 45, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}}
var b44 = charBuilder{}
b45.items = []builder{&b44}
b46.items = []builder{&b43, &b45}
b47.options = []builder{&b41, &b46}
b48.items = []builder{&b47}
var b49 = sequenceBuilder{id: 49, commit: 2, ranges: [][]int{{0, -1}, {1, 1}}}
b49.items = []builder{&b65, &b48}
b50.items = []builder{&b48, &b49}
b51.options = []builder{&b50, &b27}
b57.items = []builder{&b56, &b65, &b51}
b58.items = []builder{&b54, &b65, &b39, &b65, &b57, &b65, &b8}
var b60 = sequenceBuilder{id: 60, commit: 10, allChars: true, ranges: [][]int{{1, 1}, {1, 1}}, generalizations: []int{61}}
var b59 = charBuilder{}
b60.items = []builder{&b59}
b61.options = []builder{&b58, &b8, &b60}
var b62 = sequenceBuilder{id: 62, commit: 2, ranges: [][]int{{0, -1}, {1, 1}}}
b62.items = []builder{&b65, &b61}
b63.items = []builder{&b61, &b62}
b66.items = []builder{&b63}
b67.items = []builder{&b65, &b66, &b65}
var keywords = []parser{}
return parseInput(r, &p67, &b67, keywords)
}