aboutsummaryrefslogtreecommitdiffstats
path: root/ethlog/loggers.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2014-07-07 16:53:25 +0800
committerobscuren <geffobscura@gmail.com>2014-07-07 16:53:25 +0800
commit9dab7dcc3c99d387ad2c0a1623b574d3023bdfae (patch)
tree8f98cce69568d29a954410e18dce8c121d25592e /ethlog/loggers.go
parentd40cba3042564f3471aa20a5cf477cafcacc2189 (diff)
parentb958179263aa1fa5060dd5d5848b8bb092a4165c (diff)
downloadgo-tangerine-9dab7dcc3c99d387ad2c0a1623b574d3023bdfae.tar
go-tangerine-9dab7dcc3c99d387ad2c0a1623b574d3023bdfae.tar.gz
go-tangerine-9dab7dcc3c99d387ad2c0a1623b574d3023bdfae.tar.bz2
go-tangerine-9dab7dcc3c99d387ad2c0a1623b574d3023bdfae.tar.lz
go-tangerine-9dab7dcc3c99d387ad2c0a1623b574d3023bdfae.tar.xz
go-tangerine-9dab7dcc3c99d387ad2c0a1623b574d3023bdfae.tar.zst
go-tangerine-9dab7dcc3c99d387ad2c0a1623b574d3023bdfae.zip
Merge branch 'develop' of github.com-obscure:ethereum/eth-go into develop
Diffstat (limited to 'ethlog/loggers.go')
-rw-r--r--ethlog/loggers.go57
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...))
}
}