aboutsummaryrefslogtreecommitdiffstats
path: root/ethlog/loggers.go
diff options
context:
space:
mode:
authorzelig <viktor.tron@gmail.com>2014-07-05 19:53:00 +0800
committerzelig <viktor.tron@gmail.com>2014-07-05 19:53:00 +0800
commit4fb2905b1ef764fd5e26d0eda5f4b7bf4adda195 (patch)
treef230131da69f816d7f33207268cc5b72692f17f0 /ethlog/loggers.go
parent44d0d6abd26bcaca0e1caecf798183b45fb2365a (diff)
parentb232acd04ef957fb65e1c49b330165535da7e871 (diff)
downloadgo-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.go20
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
}
}