mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2024-12-12 11:36:29 +00:00
50 lines
830 B
Go
50 lines
830 B
Go
|
package logutils
|
||
|
|
||
|
import (
|
||
|
"os"
|
||
|
"strings"
|
||
|
)
|
||
|
|
||
|
func getEnabledDebugs() map[string]bool {
|
||
|
ret := map[string]bool{}
|
||
|
debugVar := os.Getenv("GL_DEBUG")
|
||
|
if debugVar == "" {
|
||
|
return ret
|
||
|
}
|
||
|
|
||
|
for _, tag := range strings.Split(debugVar, ",") {
|
||
|
ret[tag] = true
|
||
|
}
|
||
|
|
||
|
return ret
|
||
|
}
|
||
|
|
||
|
var enabledDebugs = getEnabledDebugs()
|
||
|
|
||
|
type DebugFunc func(format string, args ...interface{})
|
||
|
|
||
|
func nopDebugf(format string, args ...interface{}) {}
|
||
|
|
||
|
func Debug(tag string) DebugFunc {
|
||
|
if !enabledDebugs[tag] {
|
||
|
return nopDebugf
|
||
|
}
|
||
|
|
||
|
logger := NewStderrLog(tag)
|
||
|
logger.SetLevel(LogLevelDebug)
|
||
|
|
||
|
return func(format string, args ...interface{}) {
|
||
|
logger.Debugf(format, args...)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func HaveDebugTag(tag string) bool {
|
||
|
return enabledDebugs[tag]
|
||
|
}
|
||
|
|
||
|
func SetupVerboseLog(log Log, isVerbose bool) {
|
||
|
if isVerbose {
|
||
|
log.SetLevel(LogLevelInfo)
|
||
|
}
|
||
|
}
|