File: main.go

package info (click to toggle)
golang-github-alecthomas-participle-v2 2.1.4-2
  • links: PTS, VCS
  • area: main
  • in suites: forky
  • size: 920 kB
  • sloc: javascript: 1,164; sh: 41; makefile: 7
file content (48 lines) | stat: -rw-r--r-- 1,177 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
package main

import (
	"github.com/alecthomas/kong"
	"github.com/alecthomas/repr"

	"github.com/alecthomas/participle/v2"
)

type Expr struct {
	Lhs  *Value  `@@`
	Tail []*Oper `@@*`
}

type Oper struct {
	Op  string `@( "|" "|" | "&" "&" | "!" "=" | ("!"|"="|"<"|">") "="? | "+" | "-" | "/" | "*" )`
	Rhs *Value `@@`
}

type Value struct {
	Number        *float64 `  @Float | @Int`
	String        *string  `| @String`
	Bool          *string  `| ( @"true" | "false" )`
	Nil           bool     `| @"nil"`
	SubExpression *Expr    `| "(" @@ ")" `
}

var (
	cli struct {
		Expr string `arg:"" help:"Expression."`
	}
	parser = participle.MustBuild[Expr]()
)

func main() {
	kctx := kong.Parse(&cli, kong.Description(`
A simple expression parser that does not capture precedence at all. Precedence
must be applied at the evaluation phase.

The advantage of this approach over expr1, which does encode precedence in
the parser, is that it is significantly less complex and less nested. The
advantage of this over the "precedenceclimbing" example is that no custom
parsing is required.
`))
	expr, err := parser.ParseString("", cli.Expr)
	kctx.FatalIfErrorf(err)
	repr.Println(expr)
}