parser.go 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716
  1. package muesli
  2. import (
  3. _ "bufio"
  4. _ "bytes"
  5. _ "errors"
  6. "fmt"
  7. _ "io"
  8. _ "os"
  9. _ "reflect"
  10. _ "runtime"
  11. _ "strings"
  12. _ "unicode"
  13. // "gitlab.com/beoran/woe/graphviz"
  14. // _ "gitlab.com/beoran/woe/monolog"
  15. )
  16. /* Grammar:
  17. Desrired syntax (verified LL(1) on smlweb.cpsc.ucalgary.ca)
  18. PROGRAM -> STATEMENTS.
  19. CLOSED -> BLOCK | LIST | PARENTHESIS .
  20. STATEMENTS -> STATEMENT STATEMENTS | .
  21. STATEMENT -> CLOSED | EXPRESSION eos | eos .
  22. COMMAND -> word PARAMETERS.
  23. PARAMETERS -> PARAMETER PARAMETERS | .
  24. PARAMETER -> WORDVALUE | GETTER | SETTER | CLOSED .
  25. EXPRESSION -> COMMAND | GETTER | SETTER | VALUE.
  26. PARENTHESIS -> closeparen EXPRESSION openparen .
  27. BLOCK -> openblock STATEMENTS closeblock .
  28. LIST -> openlist PARAMETERS closelist .
  29. VALUE -> string | int | float | symbol | type .
  30. WORDVALUE -> word | VALUE.
  31. SETTER -> set TARGET .
  32. TARGET -> word PARAMETER | GETTER PARAMETER .
  33. GETTER -> get ORIGIN .
  34. ORIGIN -> word | SETTER | GETTER .
  35. Or with simple operators variant.
  36. PROGRAM -> STATEMENTS.
  37. CLOSED -> BLOCK | LIST | PARENTHESIS .
  38. STATEMENTS -> STATEMENT STATEMENTS | .
  39. STATEMENT -> CLOSED | EXPRESSION eos | eos .
  40. COMMAND -> WORDVALUE DETAILS .
  41. DETAILS -> OPERATION | PARAMETERS .
  42. OPERATION -> operator COMMAND .
  43. PARAMETERS -> PARAMETER PARAMETERS | .
  44. PARAMETER -> WORDVALUE | GETTER | SETTER | CLOSED .
  45. EXPRESSION -> COMMAND | GETTER | SETTER.
  46. PARENTHESIS -> openparen EXPRESSION closeparen .
  47. BLOCK -> openblock STATEMENTS closeblock .
  48. LIST -> openlist PARAMETERS closelist .
  49. VALUE -> string | int | float | symbol | type .
  50. WORDVALUE -> word | VALUE.
  51. SETTER -> set TARGET .
  52. TARGET -> word PARAMETER | GETTER PARAMETER .
  53. GETTER -> get ORIGIN .
  54. GETCALL -> comma COMMAND | .
  55. ORIGIN -> word | SETTER | GETTER .
  56. Or, new syntax with operators for command chains at the top level,
  57. for easier shunting the operator into commands:
  58. PROGRAM -> STATEMENTS .
  59. STATEMENTS -> STATEMENT STATEMENTS | .
  60. STATEMENT -> BLOCK | CHAIN eos | eos .
  61. CHAIN -> COMMAND LINKS .
  62. LINKS -> LINK LINKS | .
  63. LINK -> operator EXPRESSION .
  64. EXPRESSION -> COMMAND | SUBSTITUTION | LITERAL .
  65. COMMAND -> NAME PARAMETERS .
  66. PARAMETER -> NAME | LITERAL | SUBSTITUTION | BLOCK .
  67. SUBSTITUTION -> PARENTHESIS | GETTER | SETTER | LIST .
  68. PARENTHESIS -> openparen CHAIN closeparen .
  69. BLOCK -> openblock STATEMENTS closeblock .
  70. LIST -> openlist PARAMETERS closelist .
  71. LITERAL -> string | int | float | true | false | nil .
  72. NAME -> word | type | symbol .
  73. SETTER -> set PARAMETER PARAMETER .
  74. GETTER -> get PARAMETER .
  75. semantics:
  76. - A muesli program consists of statements.
  77. - A statement is either a block, or a command chain terminated by eos, or just an eos .
  78. - A command chain consists of commands chained together with operators.
  79. - A command may be a direct command, an indirect command, or a literal value.
  80. - A () parenthesis gets substituted inline anywhere it occurs, also in the
  81. beginning of a command.
  82. - A bracketed list [ elem1 elem2 ... ] is syntactic sugar for (list elem1 elem 2)
  83. - A dollar getter $varname is syntactic sugar for (get varname)
  84. - A equals setter =varname value is syntactic sugar for (set varname value)
  85. - Therefore, parenthesis, lists, getters and setters are allowed anywhere,
  86. also in the beginning of the command with substitution semantics.
  87. - If a command starts with a substitution, it is an indirect command. The
  88. substitution is evaluated and it's value is looked up as the command name.
  89. In case the result is not a name, this is a run time error.
  90. In case the result is a list, each value of the list is executed as a command
  91. with the same parameters.
  92. - A literal evaluate to itself.
  93. - A name also evaluates as itself but is specific for direct commands.
  94. *
  95. * program -> statements
  96. * statements -> statement+
  97. * statement -> get / set / command
  98. *
  99. */
  100. type Parser struct {
  101. Lexer *Lexer
  102. current Token
  103. LoggerWrapper
  104. Errors []ParserError
  105. }
  106. // panic with this type on errors that would prevent the parser
  107. // from making progress.
  108. type ParserError struct {
  109. *Parser
  110. *Token
  111. Chain error
  112. }
  113. func (pe ParserError) Error() string {
  114. return fmt.Sprintf("%s %s", pe.Token.String(), pe.Chain.Error())
  115. }
  116. func (parser *Parser) SetLogger(logger Logger) {
  117. parser.LoggerWrapper = LoggerWrapper{logger}
  118. }
  119. func (parser *Parser) Errorf(message string, args ...interface{}) ParserError {
  120. err := fmt.Errorf(message, args...)
  121. pe := ParserError { Parser: parser, Token:&parser.current, Chain: err }
  122. parser.Errors = append(parser.Errors, pe)
  123. return pe
  124. }
  125. func (parser *Parser) Panicf(message string, args ...interface{}) {
  126. pe := parser.Errorf(message, args...)
  127. panic(pe)
  128. }
  129. func (parser *Parser) Advance() {
  130. token := parser.Lexer.Lex()
  131. parser.current = token
  132. parser.LogDebug("Next token: %s\n", token.String())
  133. }
  134. /* Skips tokens until a closer, namely ), }, ], EOX or EOF is found,
  135. * to skip parse errors, and to be able to continue parsing despite errors. */
  136. func (parser *Parser) SkipError() Token {
  137. parser.Advance()
  138. for {
  139. parser.Advance()
  140. if parser.NextIsErrorSkipped() {
  141. return parser.current
  142. }
  143. if parser.NextIs(TokenKindError, TokenKindNone) {
  144. parser.Panicf("Cannot recover from parse error. Parse ended.")
  145. }
  146. }
  147. return parser.current
  148. }
  149. /* Looks at the current token and advances the lexer if the token is of any of
  150. the token kinds given in kinds. In this case it will return the accepted
  151. token and advance the parser. Otherwise, it will call parser.Panicf with a
  152. * "Syntax error unexpected <token>".*/
  153. func (parser *Parser) Require(kinds ...TokenKind) Token {
  154. if parser.current.IsNone() {
  155. parser.Advance()
  156. }
  157. expected := ""
  158. sep := ""
  159. for _, kind := range kinds {
  160. if kind == parser.current.TokenKind {
  161. accepted := parser.current
  162. parser.Advance()
  163. parser.LogDebug("Require: Accepted token: %s\n", accepted.String())
  164. return accepted
  165. }
  166. expected = fmt.Sprintf("%s%s%s", expected, sep, kind.String())
  167. }
  168. parser.Panicf("error: expected one of the following: %s", expected)
  169. return Token{}
  170. }
  171. func (parser *Parser) NewAstError(message string, args ...interface{}) *Ast {
  172. sv := StringValue(fmt.Sprintf(message+" at token "+parser.current.String(), args))
  173. pos := parser.current.Position
  174. tok := NewToken(TokenKindError, sv, pos)
  175. parser.Errorf(message, args...)
  176. return NewAst(AstKindError, nil, EmptyAstArray(), tok)
  177. }
  178. // Also handles none or error vales of the token
  179. func (parser *Parser) NewAst(kind AstKind, parent * Ast, children []*Ast, value Token) *Ast{
  180. if value.IsNone() {
  181. return NewAstNone()
  182. }
  183. if value.IsError() {
  184. return NewAst(AstKindError, parent, children, value)
  185. }
  186. return NewAst(kind, parent, children, value)
  187. }
  188. func (parser *Parser) ParseValue() *Ast {
  189. parser.LogDebug("ParseValue: %s\n", parser.current.String())
  190. value := parser.Require(TokenKindInteger, TokenKindString,
  191. TokenKindBoolean, TokenKindNil, TokenKindFloat, TokenKindSymbol)
  192. return parser.NewAst(AstKindValue, nil, EmptyAstArray(), value)
  193. }
  194. func AstKindForToken(token Token) AstKind {
  195. switch token.TokenKind {
  196. case TokenKindInteger, TokenKindString, TokenKindBoolean,
  197. TokenKindNil, TokenKindFloat, TokenKindSymbol:
  198. return AstKindValue
  199. case TokenKindWord:
  200. return AstKindWord
  201. case TokenKindType:
  202. return AstKindType
  203. default:
  204. return AstKindError
  205. }
  206. }
  207. func (parser *Parser) ParseLiteral() *Ast {
  208. parser.LogDebug("ParseLiteral: %s\n", parser.current.String())
  209. value := parser.Require(TokenKindInteger, TokenKindString,
  210. TokenKindBoolean, TokenKindNil, TokenKindFloat)
  211. astKind := AstKindForToken(value)
  212. return parser.NewAst(astKind, nil, EmptyAstArray(), value)
  213. }
  214. func (parser *Parser) ParseName() *Ast {
  215. parser.LogDebug("ParseName: %s\n", parser.current.String())
  216. value := parser.Require(TokenKindWord, TokenKindType, TokenKindSymbol)
  217. astKind := AstKindForToken(value)
  218. return parser.NewAst(astKind, nil, EmptyAstArray(), value)
  219. }
  220. func (parser *Parser) ParseArgument() *Ast {
  221. parser.LogDebug("ParseArgument: %s\n", parser.current.String())
  222. switch {
  223. case parser.NextIsName(): return parser.ParseName()
  224. case parser.NextIsBlock(): return parser.ParseBlock()
  225. case parser.NextIsSubstitution(): return parser.ParseSubstitution()
  226. case parser.NextIsLiteral(): return parser.ParseLiteral()
  227. default: parser.Panicf("error: in argument: expected $, =, }, word or value")
  228. return nil
  229. }
  230. }
  231. func (parser *Parser) ParseArguments(extra ... *Ast) *Ast {
  232. parser.LogDebug("ParseArguments: %s\n", parser.current.String())
  233. ast := NewAstWithToken(AstKindArguments, parser.current)
  234. var children []*Ast
  235. for _, arg := range extra {
  236. children = append(children, arg)
  237. }
  238. for parser.NextIsArgument() {
  239. child := parser.ParseArgument()
  240. children = append(children, child)
  241. }
  242. ast.AppendChildren(children...)
  243. return ast
  244. }
  245. func (parser *Parser) ParseList() *Ast {
  246. parser.LogDebug("ParseList: %s\n", parser.current.String())
  247. op := parser.Require(TokenKindOpenList)
  248. if op.IsError() {
  249. return parser.NewAstError("Unexpected value.")
  250. }
  251. ast := NewAstWithToken(AstKindList, op)
  252. args := parser.ParseArguments()
  253. if AstIsError(args) {
  254. return args
  255. }
  256. if cp := parser.Require(TokenKindCloseList); cp.IsError() {
  257. return parser.NewAstError("expected closing brackets")
  258. }
  259. ast.AppendChild(args)
  260. return ast
  261. }
  262. func (parser *Parser) ParseParenthesis() *Ast {
  263. parser.LogDebug("ParseParenthesis: %s\n", parser.current.String())
  264. op := parser.Require(TokenKindOpenParen)
  265. if op.IsError() {
  266. return parser.NewAstError("Unexpected value.")
  267. }
  268. ast := NewAstWithToken(AstKindParenthesis, op)
  269. expr := parser.ParseChain()
  270. if expr.IsNone() {
  271. return parser.NewAstError("expected chain")
  272. }
  273. if AstIsError(expr) {
  274. return expr
  275. }
  276. if cp := parser.Require(TokenKindCloseParen); cp.IsError() {
  277. return parser.NewAstError("expected closing parenthesis")
  278. }
  279. ast.AppendChild(expr)
  280. return ast
  281. }
  282. func (parser *Parser) ParseBlock() *Ast {
  283. parser.LogDebug("ParseBlock: %s\n", parser.current.String())
  284. op := parser.Require(TokenKindOpenBlock)
  285. if op.IsError() {
  286. return parser.NewAstError("Unexpected value.")
  287. }
  288. ast := NewAstWithToken(AstKindBlock, op)
  289. stats := parser.ParseStatements()
  290. if stats.IsNone() {
  291. return parser.NewAstError("expected expression")
  292. }
  293. if AstIsError(stats) {
  294. return stats
  295. }
  296. if cp := parser.Require(TokenKindCloseBlock); cp.IsError() {
  297. return parser.NewAstError("expected closing block")
  298. }
  299. ast.AppendChild(stats)
  300. return ast
  301. }
  302. func (parser *Parser) RequireName() Token {
  303. return parser.Require(TokenKindWord, TokenKindType, TokenKindSymbol)
  304. }
  305. /* Parses the target of a set expression */
  306. func (parser *Parser) ParseTarget() *Ast {
  307. parser.LogDebug("ParseTarget: %s\n", parser.current.String())
  308. var target *Ast
  309. switch {
  310. case parser.NextIsName():
  311. // Direct target to a set
  312. token := parser.RequireName()
  313. target = NewAstWithToken(AstKindTarget, token)
  314. case parser.NextIsSubstitution():
  315. // Indirect target
  316. target = NewAstWithToken(AstKindTarget, parser.current)
  317. target.AppendChild(parser.ParseSubstitution())
  318. default:
  319. parser.Panicf("Malformed setter.")
  320. return nil
  321. }
  322. argument := parser.ParseArgument()
  323. if argument.IsNone() {
  324. return parser.NewAstError("Expected argument to set")
  325. }
  326. target.AppendChild(argument)
  327. return target
  328. }
  329. /* Parses the origin of a get expression */
  330. func (parser *Parser) ParseOrigin() *Ast {
  331. parser.LogDebug("ParseOrigin: %s\n", parser.current.String())
  332. var target *Ast
  333. switch {
  334. case parser.NextIsName():
  335. // Direct target to a set
  336. token := parser.RequireName()
  337. target = NewAstWithToken(AstKindTarget, token)
  338. case parser.NextIsSubstitution():
  339. target = NewAstWithToken(AstKindTarget, parser.current)
  340. target.AppendChild(parser.ParseSubstitution())
  341. default:
  342. parser.Panicf("Malformed getter")
  343. return nil
  344. }
  345. return target
  346. }
  347. func (parser *Parser) ParseSet() *Ast {
  348. parser.LogDebug("ParseSet: %s\n", parser.current.String())
  349. set := parser.Require(TokenKindSet)
  350. ast := NewAstWithToken(AstKindSet, set)
  351. target := parser.ParseTarget()
  352. ast.AppendChild(target)
  353. return ast
  354. }
  355. func (parser *Parser) ParseGet() *Ast {
  356. parser.LogDebug("ParseGet: %s\n", parser.current.String())
  357. get := parser.Require(TokenKindGet)
  358. ast := NewAstWithToken(AstKindGet, get)
  359. target := parser.ParseOrigin()
  360. ast.AppendChild(target)
  361. return ast
  362. }
  363. func (parser *Parser) ParseCommand() *Ast {
  364. parser.LogDebug("ParseCommand: %s\n", parser.current.String())
  365. word := parser.Require(TokenKindWord, TokenKindType)
  366. arguments := parser.ParseArguments()
  367. command := NewAstWithToken(AstKindCommand, word)
  368. command.AppendChild(arguments)
  369. return command
  370. }
  371. func (parser *Parser) ParseSubstitution() *Ast {
  372. parser.LogDebug("ParseSubstitution: %s\n", parser.current.String())
  373. switch {
  374. case parser.NextIs(TokenKindOpenParen): return parser.ParseParenthesis()
  375. case parser.NextIs(TokenKindOpenList): return parser.ParseList()
  376. case parser.NextIs(TokenKindGet): return parser.ParseGet()
  377. case parser.NextIs(TokenKindSet): return parser.ParseSet()
  378. default:
  379. parser.Panicf("Syntax error in substitution, expected $, =, (, [")
  380. return nil
  381. }
  382. }
  383. func (parser *Parser) ParseExpression() *Ast {
  384. parser.LogDebug("ParseExpression: %s\n", parser.current.String())
  385. switch {
  386. case parser.NextIsWord(): return parser.ParseCommand()
  387. case parser.NextIsSubstitution(): return parser.ParseSubstitution()
  388. case parser.NextIsLiteral(): return parser.ParseLiteral()
  389. default:
  390. parser.Panicf("Syntax error in expression, expected word, $, =, value")
  391. return nil
  392. }
  393. }
  394. func (parser *Parser) ParseExpressionStatement() *Ast {
  395. parser.LogDebug("ParseExpressionStatement: %s\n", parser.current.String())
  396. expr := parser.ParseExpression()
  397. if expr.IsNone() {
  398. return NewAstNone()
  399. }
  400. // Expression statements must end on EOX or EOF
  401. if eox := parser.Require(TokenKindEOX, TokenKindEOF); eox.IsError() {
  402. return parser.NewAstError("expected end of statement")
  403. }
  404. return expr
  405. }
  406. func (parser *Parser) ParseEmptyStatement() *Ast {
  407. parser.LogDebug("ParseEmptyStatement: %s\n", parser.current.String())
  408. if eox := parser.Require(TokenKindEOX, TokenKindEOF); eox.IsError() {
  409. return parser.NewAstError("expected end of statement")
  410. }
  411. return NewAstWithToken(AstKindStatement, parser.current)
  412. }
  413. func (parser Parser) NextIs(kinds ...TokenKind) bool {
  414. if (parser.current.TokenKind == TokenKindNone) {
  415. parser.Advance()
  416. }
  417. for _, kind := range kinds {
  418. if kind == parser.current.TokenKind {
  419. return true
  420. }
  421. }
  422. return false
  423. }
  424. func (parser Parser) NextIsBlock() bool {
  425. return parser.NextIs(TokenKindOpenBlock)
  426. }
  427. func (parser Parser) NextIsSubstitution() bool {
  428. return parser.NextIs(TokenKindOpenList, TokenKindOpenParen,
  429. TokenKindSet, TokenKindGet)
  430. }
  431. func (parser Parser) NextIsWord() bool {
  432. return parser.NextIs(TokenKindWord)
  433. }
  434. func (parser Parser) NextIsGet() bool {
  435. return parser.NextIs(TokenKindGet)
  436. }
  437. func (parser Parser) NextIsSet() bool {
  438. return parser.NextIs(TokenKindSet)
  439. }
  440. func (parser Parser) NextIsLiteral() bool {
  441. return parser.NextIs(TokenKindString, TokenKindInteger, TokenKindFloat,
  442. TokenKindBoolean, TokenKindNil)
  443. }
  444. func (parser Parser) NextIsName() bool {
  445. return parser.NextIs(TokenKindWord, TokenKindType, TokenKindSymbol)
  446. }
  447. func (parser Parser) NextIsOperator() bool {
  448. return parser.NextIs(TokenKindOperator)
  449. }
  450. func (parser Parser) NextIsArgument() bool {
  451. return parser.NextIsName() || parser.NextIsLiteral() ||
  452. parser.NextIsSubstitution() || parser.NextIsBlock()
  453. }
  454. func (parser Parser) NextIsCommand() bool {
  455. return parser.NextIsName()
  456. }
  457. func (parser Parser) NextIsErrorSkipped() bool {
  458. return parser.NextIs(TokenKindCloseBlock, TokenKindCloseList, TokenKindCloseParen,
  459. TokenKindEOX, TokenKindEOF)
  460. }
  461. func (parser Parser) NextIsEOX() bool {
  462. return parser.NextIs(TokenKindEOX)
  463. }
  464. func (parser Parser) NextIsEOF() bool {
  465. return parser.NextIs(TokenKindEOF)
  466. }
  467. func (parser Parser) NextIsExpression() bool {
  468. return parser.NextIsCommand() || parser.NextIsSubstitution() ||
  469. parser.NextIsLiteral()
  470. }
  471. func (parser Parser) NextIsChain() bool {
  472. return parser.NextIsExpression()
  473. }
  474. func (parser Parser) NextIsStatement() bool {
  475. return parser.NextIsChain() || parser.NextIsBlock() || parser.NextIsEOX()
  476. }
  477. func (parser *Parser) ParseChain() *Ast {
  478. expression := parser.ParseExpression()
  479. if !parser.NextIsOperator() {
  480. return expression
  481. }
  482. var expressions = []*Ast{ expression }
  483. var operators = []Token {}
  484. for parser.NextIsOperator() {
  485. oper := parser.Require(TokenKindOperator)
  486. expression := parser.ParseExpression()
  487. if expression == nil {
  488. parser.Panicf("Expected expression after operator.")
  489. }
  490. expressions = append(expressions, expression)
  491. operators = append(operators, oper)
  492. }
  493. // now there are N expressions and N - 1 operators, iterate backwards
  494. // for easy composition
  495. var chain *Ast
  496. for i, j := 0, 0 ; i < len(expressions) && j < len(operators) ; i, j = i + 1 , j + 1 {
  497. expression := expressions[i]
  498. oper := operators[j]
  499. if chain == nil {
  500. expression2 := expressions[i+1]
  501. subst1 := NewAstWithToken(AstKindParenthesis, oper)
  502. subst1.AppendChildren(expression)
  503. subst2 := NewAstWithToken(AstKindParenthesis, oper)
  504. subst2.AppendChildren(expression2)
  505. chain = NewAstWithToken(AstKindOperation, oper)
  506. chain.AppendChildren(subst1, subst2)
  507. i++
  508. } else {
  509. subst := NewAstWithToken(AstKindParenthesis, oper)
  510. subst.AppendChildren(expression)
  511. newChain := NewAstWithToken(AstKindOperation, oper)
  512. newChain.AppendChildren(chain, subst)
  513. chain = newChain
  514. }
  515. }
  516. return chain
  517. }
  518. func (parser *Parser) ParseStatement() *Ast {
  519. parser.LogDebug("ParseStatement: %s\n", parser.current.String())
  520. switch {
  521. case parser.NextIsBlock(): return parser.ParseBlock()
  522. case parser.NextIsExpression(): return parser.ParseChain()
  523. case parser.NextIsEOX(): return parser.ParseEmptyStatement()
  524. default:
  525. parser.Panicf("Expected block, command, or EOX in statement")
  526. return parser.NewAstError("Expected closed, expression, or EOX in statement")
  527. }
  528. }
  529. func (parser *Parser) ParseStatements() *Ast {
  530. parser.LogDebug("ParseStatements: %s\n", parser.current.String())
  531. ast := NewAstWithToken(AstKindStatements, parser.current)
  532. var children []*Ast
  533. for parser.NextIsStatement() {
  534. child := parser.ParseStatement()
  535. children = append(children, child)
  536. }
  537. ast.AppendChildren(children...)
  538. return ast
  539. }
  540. func (parser *Parser) ParseProgram() *Ast {
  541. parser.LogDebug("ParseProgram: %s\n", parser.current.String())
  542. stats := parser.ParseStatements()
  543. eof := parser.Require(TokenKindEOF)
  544. aeof := NewAstWithToken(AstKindEnd, eof)
  545. if eof.IsNone() {
  546. aeof = parser.NewAstError("Expected EOF, have: %s", parser.current.String())
  547. }
  548. children := []*Ast{stats, aeof}
  549. return NewAst(AstKindProgram, nil, children, NoToken())
  550. }
  551. func (parser *Parser) Parse() (ast *Ast) {
  552. defer func() {
  553. if err := recover() ; err != nil {
  554. if perr, ok := err.(ParserError) ; ok{
  555. ast = parser.NewAstError("Parse error, recovered: %s\n", perr)
  556. } else {
  557. panic(err)
  558. }
  559. }
  560. } ()
  561. parser.Advance()
  562. ast = parser.ParseProgram()
  563. return ast
  564. }
  565. func NewParser(lexer *Lexer) *Parser {
  566. parser := &Parser{Lexer: lexer, current: NoToken(), LoggerWrapper: LoggerWrapper{nil}}
  567. return parser
  568. }
  569. func NewParserFromString(input string) *Parser {
  570. lexer := NewLexerFromString(input)
  571. return NewParser(lexer)
  572. }
  573. func NewParserFromFilename(filename string) (*Parser, error) {
  574. lexer, err := NewLexerFromFilename(filename)
  575. if err != nil {
  576. return nil, err
  577. }
  578. return NewParser(lexer), nil
  579. }
  580. func (parser * Parser) NewKeyword(name string, tk TokenKind, val Value) *Keyword {
  581. return parser.Lexer.NewKeyword(name, tk, val)
  582. }
  583. func (parser * Parser) AddKeyword(kw * Keyword) *Keyword {
  584. return parser.Lexer.AddKeyword(kw)
  585. }
  586. func (parser * Parser) AddKeywords(keywords []*Keyword) {
  587. for _, kw := range keywords {
  588. parser.AddKeyword(kw)
  589. }
  590. }
  591. func (parser * Parser) AddDefaultKeywords() {
  592. parser.AddKeywords(DefaultKeywords)
  593. }