當前位置: 首頁>>代碼示例>>Golang>>正文


Golang Lexer.Unread方法代碼示例

本文整理匯總了Golang中github.com/hialin/hialin/parse/internal/engine/lexer.Lexer.Unread方法的典型用法代碼示例。如果您正苦於以下問題:Golang Lexer.Unread方法的具體用法?Golang Lexer.Unread怎麽用?Golang Lexer.Unread使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在github.com/hialin/hialin/parse/internal/engine/lexer.Lexer的用法示例。


在下文中一共展示了Lexer.Unread方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1: Parse

func (p *Parser) Parse(lex lexer.Lexer) (interface{}, error) {
	defer tlog.FuncLog(tlog.Func("Parse"))

	stateStack := []ItemSetID{ItemSetID(0)}
	dataStack := make([]interface{}, 1, 1) // first is nil
	tok, err := p.nextToken(lex)
	if err != nil {
		return tok, err
	}
	if p.debug {
		fmt.Println("\nInitial token", tok.String(p.Syms), p.fmtStacks(stateStack, dataStack))
	}
	for {
		topState := stateStack[len(stateStack)-1]
		action, found := p.parsetable[topState][tok.ID]
		if !found {
			action, found = p.parsetable[topState][syms.EMPTY]
			if found {
				lex.Unread()
				tok = lexer.Token{ID: syms.EMPTY, Str: ""}
			}
		}
		if !found {
			// parsing error
			tok, stateStack, dataStack, err = p.errorRecovery(lex, tok, stateStack, dataStack)
			_ = "breakpoint"
			if err != nil {
				return dataStack, err
			}
			topState = stateStack[len(stateStack)-1]
			action, found = p.parsetable[topState][tok.ID]
		}

		if action.actiontype == Shift {
			stateStack = append(stateStack, action.state)
			dataStack = append(dataStack, tok)
			if p.debug {
				fmt.Println("\nShifted token", tok.String(p.Syms), p.fmtStacks(stateStack, dataStack))
			}
			tok, err = p.nextToken(lex)
			if err != nil {
				dataStack = append(dataStack, tok)
				return dataStack, err
			}
		} else if action.actiontype == Reduce {
			rule := p.Rules.Get(action.ruleID)

			cutoff := len(stateStack) - len(rule.RHS)
			if cutoff < 0 {
				tlog.Panic("should reduce, but not enough elements on stack.",
					"\nReduce before token ", tok.String(p.Syms),
					"\nRule: ", rule.String(*p.Syms, -1),
					p.fmtStacks(stateStack, dataStack))
			}

			userFn := rule.UserFn
			if userFn == nil {
				userFn = grammar.NilUserFn
			}
			newdata, err := userFn(p.Grammar, rule, dataStack[cutoff:])
			if err != nil {
				return newdata, UserCallbackParseError(
					fmt.Sprint("user callback error on reduce. ",
						"\nReduce before token ", tok.String(p.Syms),
						"\nRule: ", rule.String(*p.Syms, -1),
						p.fmtStacks(stateStack, dataStack)))
			}
			dataStack = dataStack[:cutoff]
			dataStack = append(dataStack, newdata)

			stateStack = stateStack[:cutoff]
			topState = stateStack[len(stateStack)-1]
			if topState == 0 && len(stateStack) == 1 && tok.ID == syms.EOF {
				if p.debug {
					fmt.Println(
						"\nFinal Reduce, before token ", tok.String(p.Syms),
						"\nRule: ", rule.String(*p.Syms, -1),
						"\nReduced to state:", topState,
						p.fmtStacks(stateStack, dataStack))
				}
				return newdata, nil
			}

			action2, found := p.parsetable[topState][rule.LHS]
			if !found {
				tlog.Panic("internal parser error, no goto state. ",
					"\nAfter Reduce, before token ", tok.String(p.Syms),
					"\nRule: ", rule.String(*p.Syms, -1),
					p.fmtStacks(stateStack, dataStack))
			}
			if action2.actiontype != Goto {
				tlog.Panic("internal parser error, expected goto action, instead got: ", action2,
					"\nAfter Reduce, before token ", tok.String(p.Syms),
					"\nRule: ", rule.String(*p.Syms, -1),
					p.fmtStacks(stateStack, dataStack))
			}
			stateStack = append(stateStack, action2.state)
			// a reduce does not consume the terminal

			if p.debug {
//.........這裏部分代碼省略.........
開發者ID:hialin,項目名稱:hialin,代碼行數:101,代碼來源:parser.go


注:本文中的github.com/hialin/hialin/parse/internal/engine/lexer.Lexer.Unread方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。