diff options
author | zelig <viktor.tron@gmail.com> | 2014-07-05 19:53:00 +0800 |
---|---|---|
committer | zelig <viktor.tron@gmail.com> | 2014-07-05 19:53:00 +0800 |
commit | 4fb2905b1ef764fd5e26d0eda5f4b7bf4adda195 (patch) | |
tree | f230131da69f816d7f33207268cc5b72692f17f0 /ethlog/loggers.go | |
parent | 44d0d6abd26bcaca0e1caecf798183b45fb2365a (diff) | |
parent | b232acd04ef957fb65e1c49b330165535da7e871 (diff) | |
download | go-tangerine-4fb2905b1ef764fd5e26d0eda5f4b7bf4adda195.tar go-tangerine-4fb2905b1ef764fd5e26d0eda5f4b7bf4adda195.tar.gz go-tangerine-4fb2905b1ef764fd5e26d0eda5f4b7bf4adda195.tar.bz2 go-tangerine-4fb2905b1ef764fd5e26d0eda5f4b7bf4adda195.tar.lz go-tangerine-4fb2905b1ef764fd5e26d0eda5f4b7bf4adda195.tar.xz go-tangerine-4fb2905b1ef764fd5e26d0eda5f4b7bf4adda195.tar.zst go-tangerine-4fb2905b1ef764fd5e26d0eda5f4b7bf4adda195.zip |
Merge branch 'develop' of github.com:ethereum/eth-go into feature/ethutil-refactor
Diffstat (limited to 'ethlog/loggers.go')
-rw-r--r-- | ethlog/loggers.go | 20 |
1 files changed, 14 insertions, 6 deletions
diff --git a/ethlog/loggers.go b/ethlog/loggers.go index 9ebe59096..219c78240 100644 --- a/ethlog/loggers.go +++ b/ethlog/loggers.go @@ -39,7 +39,7 @@ func (msg *logMessage) send(logger LogSystem) { var logMessages chan (*logMessage) var logSystems []LogSystem -var drained = true +var quit chan bool type LogLevel uint8 @@ -54,6 +54,7 @@ const ( // log messages are dispatched to log writers func start() { +out: for { select { case msg := <-logMessages: @@ -62,15 +63,23 @@ func start() { msg.send(logSystem) } } - default: - drained = true + case <-quit: + break out } } } // waits until log messages are drained (dispatched to log writers) func Flush() { - for !drained { + quit <- true + +done: + for { + select { + case <-logMessages: + default: + break done + } } } @@ -88,6 +97,7 @@ func AddLogSystem(logSystem LogSystem) { defer mutex.Unlock() if logSystems == nil { logMessages = make(chan *logMessage) + quit = make(chan bool) go start() } logSystems = append(logSystems, logSystem) @@ -96,7 +106,6 @@ func AddLogSystem(logSystem LogSystem) { func (logger *Logger) sendln(level LogLevel, v ...interface{}) { if logMessages != nil { msg := newPrintlnLogMessage(level, logger.tag, v...) - drained = false logMessages <- msg } } @@ -104,7 +113,6 @@ func (logger *Logger) sendln(level LogLevel, v ...interface{}) { func (logger *Logger) sendf(level LogLevel, format string, v ...interface{}) { if logMessages != nil { msg := newPrintfLogMessage(level, logger.tag, format, v...) - drained = false logMessages <- msg } } |