parser.go 22 KB

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