feat: better recursive descent

This commit is contained in:
2025-12-27 01:18:06 -05:00
parent e3629acb45
commit a05a63627e
13 changed files with 316 additions and 221 deletions

View File

@@ -0,0 +1,22 @@
package ast
import "fmt"
type Visitor[T any] interface {
VisitAtom(*Atom) T
VisitAbstraction(*Abstraction) T
VisitApplication(*Application) T
}
func Visit[T any](visitor Visitor[T], node Expression) T {
switch node := node.(type) {
case *Atom:
return visitor.VisitAtom(node)
case *Abstraction:
return visitor.VisitAbstraction(node)
case *Application:
return visitor.VisitApplication(node)
default:
panic(fmt.Sprintf("unknown node %t", node))
}
}