示例#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 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
}
示例#5
0
文件: lex.go 项目: rwcarlsen/goledger
func lexBlankLine(l *lex.Lexer) lex.StateFn {
	l.AcceptRun(indent)
	l.Ignore()

	if l.AcceptRun(lineend) == 0 {
		l.Errorf("unexpected non-blank line at line %v", l.LineNumber())
		return lexSkipLine
	}
	l.Ignore()
	return nil
}
示例#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 lexItems(l *lex.Lexer) lex.StateFn {
	if l.AcceptRun(indent) == 0 {
		return nil
	} else if string(l.Peek()) == meta {
		l.Push(lexItems)
		return lexMeta
	}

	l.Ignore()

	l.Push(lexItems)
	return lexItem
}
示例#9
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
}
示例#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 lexSkipLine(l *lex.Lexer) lex.StateFn {
	l.AcceptRunNot(lineend)
	l.AcceptRun(lineend)
	l.Ignore()
	return nil
}