diff options
author | zelig <viktor.tron@gmail.com> | 2014-07-06 01:36:22 +0800 |
---|---|---|
committer | zelig <viktor.tron@gmail.com> | 2014-07-06 02:11:08 +0800 |
commit | d4300c406c5f98d35857b6e53b0427be5f45e3b2 (patch) | |
tree | 473019889121dd7f493b56f7d1dd6883c1b7ba4f /ethlog/loggers.go | |
parent | 4fb2905b1ef764fd5e26d0eda5f4b7bf4adda195 (diff) | |
download | go-tangerine-d4300c406c5f98d35857b6e53b0427be5f45e3b2.tar go-tangerine-d4300c406c5f98d35857b6e53b0427be5f45e3b2.tar.gz go-tangerine-d4300c406c5f98d35857b6e53b0427be5f45e3b2.tar.bz2 go-tangerine-d4300c406c5f98d35857b6e53b0427be5f45e3b2.tar.lz go-tangerine-d4300c406c5f98d35857b6e53b0427be5f45e3b2.tar.xz go-tangerine-d4300c406c5f98d35857b6e53b0427be5f45e3b2.tar.zst go-tangerine-d4300c406c5f98d35857b6e53b0427be5f45e3b2.zip |
logger fix
- introduce quit, drained, shutdown channels
- mainLoop falls through reading message channel to drained state, and waits is blocked in default branch until any message is sent
- Flush() waits for <-drained
- Stop() pushes quit and nodges mainloop out of blocking drained state
- package-global mutex
- Reset()
- clear tests
Diffstat (limited to 'ethlog/loggers.go')
-rw-r--r-- | ethlog/loggers.go | 57 |
1 files changed, 39 insertions, 18 deletions
diff --git a/ethlog/loggers.go b/ethlog/loggers.go index 219c78240..d7707cf9e 100644 --- a/ethlog/loggers.go +++ b/ethlog/loggers.go @@ -40,6 +40,9 @@ func (msg *logMessage) send(logger LogSystem) { var logMessages chan (*logMessage) var logSystems []LogSystem var quit chan bool +var drained chan bool +var shutdown chan bool +var mutex = sync.Mutex{} type LogLevel uint8 @@ -57,29 +60,41 @@ func start() { out: for { select { + case <-quit: + break out case msg := <-logMessages: for _, logSystem := range logSystems { if logSystem.GetLogLevel() >= msg.LogLevel { msg.send(logSystem) } } - case <-quit: - break out + case drained <- true: + default: + drained <- true // this blocks until a message is sent to the queu } } + close(shutdown) } -// waits until log messages are drained (dispatched to log writers) -func Flush() { - quit <- true - -done: - for { +func Reset() { + mutex.Lock() + defer mutex.Unlock() + if logSystems != nil { + quit <- true select { - case <-logMessages: - default: - break done + case <-drained: } + <-shutdown + } + logSystems = nil +} + +// waits until log messages are drained (dispatched to log writers) +func Flush() { + mutex.Lock() + defer mutex.Unlock() + if logSystems != nil { + <-drained } } @@ -92,28 +107,34 @@ func NewLogger(tag string) *Logger { } func AddLogSystem(logSystem LogSystem) { - var mutex = &sync.Mutex{} mutex.Lock() defer mutex.Unlock() if logSystems == nil { logMessages = make(chan *logMessage) quit = make(chan bool) + drained = make(chan bool, 1) + shutdown = make(chan bool, 1) go start() } logSystems = append(logSystems, logSystem) } +func send(msg *logMessage) { + select { + case <-drained: + } + logMessages <- msg +} + func (logger *Logger) sendln(level LogLevel, v ...interface{}) { - if logMessages != nil { - msg := newPrintlnLogMessage(level, logger.tag, v...) - logMessages <- msg + if logSystems != nil { + send(newPrintlnLogMessage(level, logger.tag, v...)) } } func (logger *Logger) sendf(level LogLevel, format string, v ...interface{}) { - if logMessages != nil { - msg := newPrintfLogMessage(level, logger.tag, format, v...) - logMessages <- msg + if logSystems != nil { + send(newPrintfLogMessage(level, logger.tag, format, v...)) } } |