示例#1
0
文件: lex.go 项目: rwcarlsen/goledger
func lexCommod(l *lex.Lexer) lex.StateFn {
	l.AcceptRun(indent)
	l.Ignore()
	if l.AcceptRunNot(whitespace+meta+at) > 0 {
		l.Emit(tokCommod)
	}
	return nil
}
示例#2
0
文件: lex.go 项目: rwcarlsen/goledger
func lexStatus(l *lex.Lexer) lex.StateFn {
	l.AcceptRun(indent)
	l.Ignore()
	if l.Accept(statuss) {
		l.Emit(tokStatus)
	}
	return nil
}
示例#3
0
文件: lex.go 项目: rwcarlsen/goledger
func lexNewline(l *lex.Lexer) lex.StateFn {
	l.AcceptRun(indent)
	if l.AcceptRun(lineend) == 0 {
		l.Errorf("lexer error - missing expected newline")
	} else {
		l.Emit(tokNewline)
	}
	return nil
}
示例#4
0
文件: lex.go 项目: rwcarlsen/goledger
func lexTrans(l *lex.Lexer) lex.StateFn {
	l.Emit(tokBeginTrans)

	l.Push(lexEndTrans)
	l.Push(lexItems)
	l.Push(lexMeta)
	l.Push(lexPayee)
	l.Push(lexStatus)
	return lexDate
}
示例#5
0
文件: lex.go 项目: rwcarlsen/goledger
func lexMeta(l *lex.Lexer) lex.StateFn {
	l.AcceptRun(indent)
	l.Ignore()
	if l.Accept(";") {
		l.Emit(tokMeta)
		l.AcceptRun(indent)
		l.Ignore()
		return lexText
	}
	return lexNewline
}
示例#6
0
文件: lex.go 项目: rwcarlsen/goledger
func lexAt(l *lex.Lexer) lex.StateFn {
	if n := l.AcceptRun(at); n > 2 {
		l.Errorf("invalid token on line %v", l.LineNumber())
		return lexSkipLine
	} else if n == 1 {
		l.Emit(tokAt)
	} else if n == 2 {
		l.Emit(tokAtAt)
	}
	return nil
}
示例#7
0
文件: lex.go 项目: rwcarlsen/goledger
func lexAccount(l *lex.Lexer) lex.StateFn {
	for {
		nr := l.Next()
		nnr := l.Peek()
		if isSpace(nr) && isSpace(nnr) || isNewline(nr) {
			l.Backup()
			l.Emit(tokAccount)
			l.AcceptRun(indent)
			l.Ignore()
			return nil
		}
	}
}
示例#8
0
文件: lex.go 项目: rwcarlsen/goledger
func lexAmount(l *lex.Lexer) lex.StateFn {
	l.AcceptRun(indent)
	l.Ignore()

	if l.Accept("$") {
		l.Emit(tokUnit)
	}

	l.AcceptRun(digit + ",")
	l.Accept(".")
	l.AcceptRun(digit)
	if l.Pos > l.Start {
		l.Emit(tokAmount)
	}
	return lexCommod
}
示例#9
0
文件: lex.go 项目: rwcarlsen/goledger
// lexStart looks for a comment or a transaction, it emits everything
// inbetween as tokText
func lexStart(l *lex.Lexer) lex.StateFn {
	switch r := l.Peek(); {
	case string(r) == meta:
		l.Push(lexStart)
		return lexMeta
	case unicode.IsDigit(r):
		l.Push(lexStart)
		return lexTrans
	case isSpace(r) || isNewline(r):
		l.Push(lexStart)
		return lexBlankLine
	case r == lex.EOF:
		l.Emit(lex.TokEOF)
		return nil
	default:
		l.Errorf("unexpected text on line %v", l.LineNumber())
		l.Push(lexStart)
		return lexSkipLine
	}
}
示例#10
0
文件: lex.go 项目: rwcarlsen/goledger
func lexDate(l *lex.Lexer) lex.StateFn {
	fail := false
	if l.AcceptRun(digit) == 0 {
		fail = true
	} else if !l.Accept("/") {
		fail = true
	} else if l.AcceptRun(digit) == 0 {
		fail = true
	} else if !l.Accept("/") {
		fail = true
	} else if l.AcceptRun(digit) == 0 {
		fail = true
	}

	if fail {
		l.AcceptRunNot(whitespace + meta)
		l.Errorf("invalid date on line %v", l.LineNumber())
		l.Ignore()
	} else {
		l.Emit(tokDate)
	}
	return nil
}
示例#11
0
文件: lex.go 项目: rwcarlsen/goledger
func lexEndTrans(l *lex.Lexer) lex.StateFn {
	l.Emit(tokEndTrans)
	return nil
}
示例#12
0
文件: lex.go 项目: rwcarlsen/goledger
func lexText(l *lex.Lexer) lex.StateFn {
	l.AcceptRunNot(lineend + meta)
	l.Emit(tokText)
	return lexNewline
}
示例#13
0
文件: lex.go 项目: rwcarlsen/goledger
func lexPayee(l *lex.Lexer) lex.StateFn {
	if l.AcceptRunNot(lineend+meta) > 0 {
		l.Emit(tokPayee)
	}
	return nil
}