Cleanup: Remove parser switching logic (#6583)

During the PromQL parser rewrite there was some logic put in place that allowed switching between the non generated and the generated parser. Since the parser is now fully generated this is not needed anymore.

Signed-off-by: Tobias Guggenmos <tguggenm@redhat.com>
This commit is contained in:
Tobias Guggenmos 2020-01-08 15:59:25 +01:00 committed by Brian Brazil
parent 2064abab40
commit 4aef43a9f5

View file

@ -35,8 +35,6 @@ type parser struct {
inject Item inject Item
injecting bool injecting bool
switchSymbols []ItemType
generatedParserResult interface{} generatedParserResult interface{}
} }
@ -58,7 +56,7 @@ func ParseExpr(input string) (expr Expr, err error) {
defer p.recover(&err) defer p.recover(&err)
expr = p.parseGenerated(START_EXPRESSION, []ItemType{EOF}).(Expr) expr = p.parseGenerated(START_EXPRESSION).(Expr)
err = p.typecheck(expr) err = p.typecheck(expr)
return expr, err return expr, err
@ -69,7 +67,7 @@ func ParseMetric(input string) (m labels.Labels, err error) {
p := newParser(input) p := newParser(input)
defer p.recover(&err) defer p.recover(&err)
return p.parseGenerated(START_METRIC, []ItemType{EOF}).(labels.Labels), nil return p.parseGenerated(START_METRIC).(labels.Labels), nil
} }
// ParseMetricSelector parses the provided textual metric selector into a list of // ParseMetricSelector parses the provided textual metric selector into a list of
@ -78,7 +76,7 @@ func ParseMetricSelector(input string) (m []*labels.Matcher, err error) {
p := newParser(input) p := newParser(input)
defer p.recover(&err) defer p.recover(&err)
return p.parseGenerated(START_METRIC_SELECTOR, []ItemType{EOF}).(*VectorSelector).LabelMatchers, nil return p.parseGenerated(START_METRIC_SELECTOR).(*VectorSelector).LabelMatchers, nil
} }
// newParser returns a new parser. // newParser returns a new parser.
@ -115,7 +113,7 @@ func parseSeriesDesc(input string) (labels labels.Labels, values []sequenceValue
defer p.recover(&err) defer p.recover(&err)
result := p.parseGenerated(START_SERIES_DESCRIPTION, []ItemType{EOF}).(*seriesDescription) result := p.parseGenerated(START_SERIES_DESCRIPTION).(*seriesDescription)
labels = result.labels labels = result.labels
values = result.values values = result.values
@ -222,10 +220,8 @@ func (p *parser) Lex(lval *yySymType) int {
typ := lval.item.Typ typ := lval.item.Typ
for _, t := range p.switchSymbols { if typ == EOF {
if t == typ { p.InjectItem(0)
p.InjectItem(0)
}
} }
return int(typ) return int(typ)
@ -526,15 +522,9 @@ func parseDuration(ds string) (time.Duration, error) {
// parseGenerated invokes the yacc generated parser. // parseGenerated invokes the yacc generated parser.
// The generated parser gets the provided startSymbol injected into // The generated parser gets the provided startSymbol injected into
// the lexer stream, based on which grammar will be used. // the lexer stream, based on which grammar will be used.
// func (p *parser) parseGenerated(startSymbol ItemType) interface{} {
// The generated parser will consume the lexer Stream until one of the
// tokens listed in switchSymbols is encountered. switchSymbols
// should at least contain EOF
func (p *parser) parseGenerated(startSymbol ItemType, switchSymbols []ItemType) interface{} {
p.InjectItem(startSymbol) p.InjectItem(startSymbol)
p.switchSymbols = switchSymbols
yyParse(p) yyParse(p)
return p.generatedParserResult return p.generatedParserResult