ast.go 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572
  1. // Abstract Syntax tree for the MUESLI interpreter
  2. package muesli
  3. import (
  4. "fmt"
  5. "strings"
  6. "log"
  7. )
  8. type AstBasicMetaKind string
  9. type AstMetaKindNone AstBasicMetaKind
  10. type AstMetaKindProgram AstBasicMetaKind
  11. type AstMetaKindStatements AstBasicMetaKind
  12. type AstMetaKindStatement AstBasicMetaKind
  13. type AstMetaKindClosed AstBasicMetaKind
  14. type AstMetaKindSet AstBasicMetaKind
  15. type AstMetaKindGet AstBasicMetaKind
  16. type AstMetaKindTarget AstBasicMetaKind
  17. type AstMetaKindCommand AstBasicMetaKind
  18. type AstMetaKindArguments AstBasicMetaKind
  19. type AstMetaKindArgument AstBasicMetaKind
  20. type AstMetaKindExpression AstBasicMetaKind
  21. type AstMetaKindBlock AstBasicMetaKind
  22. type AstMetaKindParenthesis AstBasicMetaKind
  23. type AstMetaKindList AstBasicMetaKind
  24. type AstMetaKindCapture AstBasicMetaKind
  25. type AstMetaKindWordValue AstBasicMetaKind
  26. type AstMetaKindWord AstBasicMetaKind
  27. type AstMetaKindType AstBasicMetaKind
  28. type AstMetaKindValue AstBasicMetaKind
  29. type AstMetaKindEnd AstBasicMetaKind
  30. type AstMetaKindError AstBasicMetaKind
  31. type AstMetaKindFlatten AstBasicMetaKind
  32. /** The actual types are defined as constants, the meta types are used to be able to have different behavior for them.*/
  33. const (
  34. AstKindNone = AstMetaKindNone("None")
  35. AstKindProgram = AstMetaKindProgram("Program")
  36. AstKindStatements = AstMetaKindStatements("Statements")
  37. AstKindStatement = AstMetaKindStatement("Statement")
  38. // AstKindClosed = AstMetaKindClosed("Closed")
  39. AstKindSet = AstMetaKindSet("Set")
  40. AstKindGet = AstMetaKindGet("Get")
  41. AstKindTarget = AstMetaKindTarget("Target")
  42. AstKindCommand = AstMetaKindCommand("Command")
  43. AstKindArguments = AstMetaKindArguments("Arguments")
  44. // AstKindArgument = AstMetaKindArgument("Argument")
  45. // AstKindExpression = AstMetaKindExpression("Expression")
  46. AstKindBlock = AstMetaKindBlock("Block")
  47. AstKindParenthesis = AstMetaKindParenthesis("Parenthesis")
  48. AstKindList = AstMetaKindList("List")
  49. // AstKindCapture = AstMetaKindCapture("Capture")
  50. AstKindWordValue = AstMetaKindWordValue("WordValue")
  51. AstKindWord = AstMetaKindWord("Word")
  52. // AstKindType = AstMetaKindType("Type")
  53. AstKindValue = AstMetaKindValue("Value")
  54. AstKindEnd = AstMetaKindEnd("End")
  55. AstKindError = AstMetaKindError("Error")
  56. // AstKindFlatten is a special ast kind that insruct the parser not to generate a token
  57. AstKindFlatten = AstMetaKindFlatten("Flatten")
  58. )
  59. func (astkind AstBasicMetaKind) String() string {
  60. return string(astkind)
  61. }
  62. func (astkind AstBasicMetaKind) Run(vm *VM, ast Ast, val ...Value) []Value {
  63. return []Value{}
  64. }
  65. func (astkind AstMetaKindNone) String() string { return "AstNone " }
  66. func (astkind AstMetaKindProgram) String() string { return "AstProgram " }
  67. func (astkind AstMetaKindStatements) String() string { return "AstStatements " }
  68. func (astkind AstMetaKindStatement) String() string { return "AstStatement " }
  69. func (astkind AstMetaKindClosed) String() string { return "AstClosed " }
  70. func (astkind AstMetaKindSet) String() string { return "AstSet " }
  71. func (astkind AstMetaKindGet) String() string { return "AstGet " }
  72. func (astkind AstMetaKindTarget) String() string { return "AstTarget " }
  73. func (astkind AstMetaKindCommand) String() string { return "AstCommand " }
  74. func (astkind AstMetaKindArguments) String() string { return "AstArguments " }
  75. func (astkind AstMetaKindArgument) String() string { return "AstArgument " }
  76. func (astkind AstMetaKindExpression) String() string { return "AstExpression " }
  77. func (astkind AstMetaKindBlock) String() string { return "AstBlock " }
  78. func (astkind AstMetaKindParenthesis) String() string { return "AstParenthesis" }
  79. func (astkind AstMetaKindList) String() string { return "AstList " }
  80. func (astkind AstMetaKindCapture) String() string { return "AstCapture " }
  81. func (astkind AstMetaKindWordValue) String() string { return "AstWordValue " }
  82. func (astkind AstMetaKindWord) String() string { return "AstWord " }
  83. func (astkind AstMetaKindType) String() string { return "AstType " }
  84. func (astkind AstMetaKindValue) String() string { return "AstValue " }
  85. func (astkind AstMetaKindEnd) String() string { return "AstEnd " }
  86. func (astkind AstMetaKindError) String() string { return "AstError " }
  87. func (astkind AstMetaKindFlatten) String() string { return "AstFlatten " }
  88. func (astkind AstMetaKindNone) Run(vm *VM, ast Ast, val ...Value) []Value { return ReturnEmpty() }
  89. func (astkind AstMetaKindProgram) Run(vm *VM, ast Ast, val ...Value) []Value {
  90. return []Value{vm.RunChildrenLastResult(ast, val...)}
  91. }
  92. func (astkind AstMetaKindStatements) Run(vm *VM, ast Ast, val ...Value) []Value {
  93. return []Value{vm.RunChildrenLastResult(ast, val...)}
  94. }
  95. func (astkind AstMetaKindStatement) Run(vm *VM, ast Ast, val ...Value) []Value {
  96. panic("AstMetaKindStatement")
  97. return vm.RunChildren(ast, val...)
  98. }
  99. func (astkind AstMetaKindClosed) Run(vm *VM, ast Ast, val ...Value) []Value {return ReturnEmpty() }
  100. func (astkind AstMetaKindSet) Run(vm *VM, ast Ast, val ...Value) []Value {
  101. varName := ast.Value()
  102. value := vm.RunChildren(ast, val...)
  103. vm.Register(varName.String(), value[0])
  104. return value
  105. }
  106. func (astkind AstMetaKindGet) Run(vm *VM, ast Ast, val ...Value) []Value {
  107. target := vm.RunChildrenFirstResult(ast, val...).(ListValue)
  108. return []Value{vm.Lookup(target.String())}
  109. }
  110. func (astkind AstMetaKindTarget) Run(vm *VM, ast Ast, val ...Value) []Value {
  111. return []Value{ast.Value()}
  112. }
  113. func (astkind AstMetaKindCommand) Run(vm *VM, ast Ast, val ...Value) []Value {
  114. commandName := ast.Value()
  115. arguments := vm.RunChildrenFirstResult(ast, val...)
  116. if argList, isList := arguments.(ListValue) ; isList {
  117. log.Printf("Command execute: %s %v", commandName.String(), argList)
  118. return vm.CallNamed(commandName.String(), argList.List...)
  119. } else if _, isEmpty := arguments.(EmptyValue) ; isEmpty {
  120. return vm.CallNamed(commandName.String())
  121. } else {
  122. return []Value{NewErrorValuef("Internal error when calling %s.", commandName.String())}
  123. }
  124. }
  125. func (astkind AstMetaKindArguments) Run(vm *VM, ast Ast, val ...Value) []Value {
  126. return vm.RunChildren(ast, val...)
  127. }
  128. func (astkind AstMetaKindArgument) Run(vm *VM, ast Ast, val ...Value) []Value {
  129. panic("AstMetaKindArgument")
  130. return []Value{vm.RunChildrenFirstResult(ast, val...)}
  131. }
  132. func (astkind AstMetaKindExpression) Run(vm *VM, ast Ast, val ...Value) []Value {
  133. panic("AstMetaKindExpression")
  134. return []Value{vm.RunChildrenLastResult(ast, val...)}
  135. }
  136. func (astkind AstMetaKindBlock) Run(vm *VM, ast Ast, val ...Value) []Value {
  137. return []Value{vm.RunChildrenLastResult(ast, val...)}
  138. }
  139. func (astkind AstMetaKindParenthesis) Run(vm *VM, ast Ast, val ...Value) []Value {
  140. return []Value{vm.RunChildrenLastResult(ast, val...)}
  141. }
  142. func (astkind AstMetaKindList) Run(vm *VM, ast Ast, val ...Value) []Value {
  143. result := vm.RunChildren(ast, val...)
  144. list := ListValue{List:result}
  145. return []Value{list}
  146. }
  147. func (astkind AstMetaKindCapture) Run(vm *VM, ast Ast, val ...Value) []Value {
  148. return vm.RunChildren(ast, val...)
  149. }
  150. func (astkind AstMetaKindWordValue) Run(vm *VM, ast Ast, val ...Value) []Value {
  151. return []Value{ast.Value()}
  152. }
  153. func (astkind AstMetaKindWord) Run(vm *VM, ast Ast, val ...Value) []Value {
  154. return []Value{ast.Value()}
  155. }
  156. func (astkind AstMetaKindType) Run(vm *VM, ast Ast, val ...Value) []Value {
  157. return []Value{ast.Value()}
  158. }
  159. func (astkind AstMetaKindValue) Run(vm *VM, ast Ast, val ...Value) []Value {
  160. return []Value{ast.Value()}
  161. }
  162. func (astkind AstMetaKindEnd) Run(vm *VM, ast Ast, val ...Value) []Value {
  163. return []Value{EmptyValue{}}
  164. }
  165. func (astkind AstMetaKindError) Run(vm *VM, ast Ast, val ...Value) []Value {
  166. return []Value{ast.Value()}
  167. }
  168. func (astkind AstMetaKindFlatten) Run(vm *VM, ast Ast, val ...Value) []Value {
  169. return ReturnEmpty()
  170. }
  171. type AstKind interface {
  172. String() string
  173. Run(vm *VM, ast Ast, val ...Value) []Value
  174. }
  175. /*
  176. func (Ast Ast) String() string {
  177. switch astkind {
  178. case AstMetaKindProgram:
  179. return "AstMetaKindProgram"
  180. case AstMetaKindStatements:
  181. return "AstMetaKindStatements"
  182. case AstMetaKindStatement:
  183. return "AstMetaKindStatement"
  184. case AstMetaKindSet:
  185. return "AstMetaKindSet"
  186. case AstMetaKindGet:
  187. return "AstMetaKindGet"
  188. case AstMetaKindTarget:
  189. return "AstMetaKindTarget"
  190. case AstMetaKindCommand:
  191. return "AstMetaKindCommand"
  192. case AstMetaKindArguments:
  193. return "AstMetaKindArguments"
  194. case AstMetaKindArgument:
  195. return "AstMetaKindArgument"
  196. case AstMetaKindExpression:
  197. return "AstMetaKindExpression"
  198. case AstMetaKindBlock:
  199. return "AstMetaKindBlock"
  200. case AstMetaKindParenthesis:
  201. return "AstMetaKindParenthesis"
  202. case AstMetaKindList:
  203. return "AstMetaKindList"
  204. case AstMetaKindCapture:
  205. return "AstMetaKindCapture"
  206. case AstMetaKindWordValue:
  207. return "AstMetaKindWordValue"
  208. case AstMetaKindWord:
  209. return "AstMetaKindWord"
  210. case AstMetaKindType:
  211. return "AstMetaKindType"
  212. case AstMetaKindValue:
  213. return "AstMetaKindValue"
  214. case AstMetaKindEnd:
  215. return "AstMetaKindEnd"
  216. case AstMetaKindError:
  217. return "AstMetaKindError"
  218. default:
  219. return "Unknown AstMetaKind"
  220. }
  221. }
  222. */
  223. /*
  224. func AstAppendChild(parent Ast, child Ast) Ast {
  225. basicParent := parent.(*Ast)
  226. return basicParent.AppendChild(child)
  227. }
  228. func AstNewChild(parent Ast, kind AstMetaKind, token Token) Ast {
  229. basicParent := parent.(*Ast)
  230. return basicParent.NewChild(kind, token)
  231. }
  232. */
  233. /* AST node kind */
  234. type Ast struct {
  235. AstKind
  236. parent *Ast
  237. children []*Ast
  238. token Token
  239. }
  240. func (ast Ast) Value() Value {
  241. return ast.token.Value
  242. }
  243. func NewAst(kind AstKind, parent *Ast, children []*Ast, token Token) *Ast {
  244. ast := &Ast{AstKind: kind, parent: parent, token: token}
  245. return ast.AppendChildren(children...)
  246. }
  247. func (ast *Ast) AppendChildren(children ...*Ast) *Ast {
  248. for _, child := range children {
  249. ast.AppendChild(child)
  250. }
  251. return ast
  252. }
  253. func (ast *Ast) AppendChild(child * Ast) *Ast {
  254. child.SetParent(ast)
  255. ast.children = append(ast.children, child)
  256. return child
  257. }
  258. func (ast *Ast) NewChild(kind AstKind, token Token) *Ast {
  259. child := NewAst(kind, ast, make([]*Ast, 0), token)
  260. ast.AppendChild(child)
  261. return child
  262. }
  263. func (ast Ast) IsKind(astkind AstKind) bool {
  264. return ast.AstKind == astkind
  265. }
  266. func (ast Ast) IsError() bool {
  267. return ast.AstKind == AstKindError
  268. }
  269. func (ast Ast) IsNone() bool {
  270. return ast.AstKind == AstKindNone
  271. }
  272. func (ast Ast) IsFlatten() bool {
  273. return ast.AstKind == AstKindFlatten
  274. }
  275. func (ast Ast) Token() Token {
  276. return ast.token
  277. }
  278. func (ast Ast) Parent() *Ast {
  279. return ast.parent
  280. }
  281. func (ast Ast) Children() []*Ast {
  282. return ast.children
  283. }
  284. func (ast Ast) Kind() AstKind {
  285. return ast.AstKind
  286. }
  287. func (ast *Ast) SetParent(parent *Ast) {
  288. ast.parent = parent
  289. }
  290. func (ast Ast) Child(index int) *Ast {
  291. count := ast.CountChildren()
  292. if index < 0 || index > count {
  293. return nil
  294. }
  295. return ast.children[index]
  296. }
  297. func (ast Ast) Run(vm *VM, val ...Value) []Value {
  298. res := ast.AstKind.Run(vm, ast, val...)
  299. if vm != nil && vm.Tracer != nil {
  300. vm.Trace(*vm, ast, res...)
  301. }
  302. return res
  303. }
  304. func (ast *Ast) Walk(walker func(node *Ast) *Ast) *Ast {
  305. if found := walker(ast); found != nil {
  306. return found
  307. }
  308. for _, child := range ast.children {
  309. if found := child.Walk(walker); found != nil {
  310. return found
  311. }
  312. }
  313. return nil
  314. }
  315. func (ast Ast) String() string {
  316. return fmt.Sprintf("Ast %s: %s", ast.AstKind.String(), ast.token.String())
  317. }
  318. func (ast Ast) Display() {
  319. ast.Walk(func(node *Ast) *Ast {
  320. depth := node.Depth()
  321. fmt.Printf("%s", strings.Repeat("--", depth))
  322. if node != nil {
  323. fmt.Printf("Ast: %s\n", node.String())
  324. } else {
  325. fmt.Printf("Ast: nil node\n")
  326. }
  327. return nil
  328. })
  329. }
  330. func (ast Ast) Dump() string {
  331. result := ""
  332. ast.Walk(func(node *Ast) *Ast {
  333. depth := node.Depth()
  334. result += fmt.Sprintf("%s", strings.Repeat("--", depth))
  335. if node != nil {
  336. result += fmt.Sprintf("Ast: %s\n", node.String())
  337. } else {
  338. result += fmt.Sprintf("Ast: nil node\n")
  339. }
  340. return nil
  341. })
  342. return result
  343. }
  344. func (ast Ast) Depth() int {
  345. var depth int = 0
  346. parent := ast.Parent()
  347. for parent != nil {
  348. depth++
  349. parent = parent.Parent()
  350. }
  351. return depth
  352. }
  353. func (ast Ast) CountChildren() int {
  354. return len(ast.children)
  355. }
  356. func AstIsError(ast * Ast) bool {
  357. return ast.IsError()
  358. }
  359. func (ast Ast) Errors() []*Ast {
  360. res := make([]*Ast, 0)
  361. ast.Walk(func(node *Ast) *Ast {
  362. if node != nil && ast.IsError() {
  363. res = append(res, node)
  364. }
  365. return nil
  366. })
  367. return res
  368. }
  369. func EmptyAstArray() []*Ast {
  370. return make([]*Ast, 0)
  371. }
  372. func NewEmptyAst(astkind AstKind) *Ast {
  373. return NewAst(astkind, nil, EmptyAstArray(), NoToken())
  374. }
  375. func NewAstNone() *Ast {
  376. return NewEmptyAst(AstKindNone)
  377. }
  378. func NewAstWithToken(astkind AstKind, token Token) *Ast {
  379. return NewAst(astkind, nil, EmptyAstArray(), token)
  380. }
  381. // If AST has errors, return it as a merged error, otherwise returns nil
  382. func (ast *Ast) ToError() error {
  383. errlist := ast.Errors()
  384. if len(errlist) < 1 {
  385. return nil
  386. }
  387. sep := ""
  388. res := ""
  389. for _, err := range errlist {
  390. res = fmt.Sprintf("%s%s%s", res, sep, err)
  391. sep = "\n"
  392. }
  393. return fmt.Errorf("%s", res)
  394. }
  395. /*
  396. type AstProgram struct{ Ast }
  397. type AstStatements struct{ Ast }
  398. type AstStatement struct{ Ast }
  399. type AstSet struct{ Ast }
  400. type AstGet struct{ Ast }
  401. type AstTarget struct{ Ast }
  402. type AstCommand struct{ Ast }
  403. type AstArguments struct{ Ast }
  404. type AstArgument struct{ Ast }
  405. type AstExpression struct{ Ast }
  406. type AstBlock struct{ Ast }
  407. type AstParenthesis struct{ Ast }
  408. type AstList struct{ Ast }
  409. type AstCapture struct{ Ast }
  410. type AstWordValue struct{ Ast }
  411. type AstWord struct{ Ast }
  412. type AstType struct{ Ast }
  413. type AstValue struct{ Ast }
  414. type AstEnd struct{ Ast }
  415. type AstError struct{ Ast }
  416. */
  417. var _ Ast = Ast{}
  418. /* The kind of an AST is also it's constructor function. This is so deep I'm almost
  419. getting scared. :) */
  420. // The type is defined as a constructor
  421. /*
  422. type AstMetaKind func(parent Ast, children []Ast, token Token) Ast
  423. type AstMetaKind2 interface {
  424. New(parent Ast, children []Ast, token Token) Ast
  425. }
  426. type AstTypeProgramImp struct{}
  427. func (ap AstTypeProgramImp) New(parent Ast, children []Ast, token Token) Ast {
  428. return AstProgram{NewBasicAst(parent, children, token)}
  429. }
  430. func NewAstProgram(parent Ast, children []Ast, token Token) Ast {
  431. return AstProgram{NewBasicAst(parent, children, token)}
  432. }
  433. var AstMetaKindBasic = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast { return NewBasicAst(parent, children, token) })
  434. var AstMetaKindProgram = AstMetaKind(NewAstProgram)
  435. var AstMetaKindProgram2 = AstMetaKind2(AstTypeProgramImp{})
  436. var AstMetaKindStatements = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  437. return &AstStatements{NewBasicAst(parent, children, token)}
  438. })
  439. var AstMetaKindStatement = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  440. return &AstStatement{NewBasicAst(parent, children, token)}
  441. })
  442. var AstMetaKindSet = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  443. return &AstSet{NewBasicAst(parent, children, token)}
  444. })
  445. var AstMetaKindGet = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  446. return &AstGet{NewBasicAst(parent, children, token)}
  447. })
  448. var AstMetaKindTarget = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  449. return &AstTarget{NewBasicAst(parent, children, token)}
  450. })
  451. var AstMetaKindCommand = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  452. return &AstCommand{NewBasicAst(parent, children, token)}
  453. })
  454. var AstMetaKindArguments = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  455. return &AstArguments{NewBasicAst(parent, children, token)}
  456. })
  457. var AstMetaKindArgument = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  458. return &AstArgument{NewBasicAst(parent, children, token)}
  459. })
  460. var AstMetaKindExpression = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  461. return &AstExpression{NewBasicAst(parent, children, token)}
  462. })
  463. var AstMetaKindBlock = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  464. return &AstBlock{NewBasicAst(parent, children, token)}
  465. })
  466. var AstMetaKindParenthesis = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  467. return &AstParenthesis{NewBasicAst(parent, children, token)}
  468. })
  469. var AstMetaKindList = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  470. return &AstList{NewBasicAst(parent, children, token)}
  471. })
  472. var AstMetaKindCapture = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  473. return &AstCapture{NewBasicAst(parent, children, token)}
  474. })
  475. var AstMetaKindWordValue = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  476. return &AstWordValue{NewBasicAst(parent, children, token)}
  477. })
  478. var AstMetaKindWord = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  479. return &AstWord{NewBasicAst(parent, children, token)}
  480. })
  481. var AstMetaKindType = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  482. return &AstType{NewBasicAst(parent, children, token)}
  483. })
  484. var AstMetaKindValue = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  485. return &AstValue{NewBasicAst(parent, children, token)}
  486. })
  487. var AstMetaKindEnd = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  488. return &AstEnd{NewBasicAst(parent, children, token)}
  489. })
  490. var AstMetaKindError = AstMetaKind(func(parent Ast, children []Ast, token Token) Ast {
  491. return &AstError{NewBasicAst(parent, children, token)}
  492. })
  493. */