712a6554ce
Fixed #8761 Signed-off-by: Alexandr Morozov <lk4d4@docker.com>
123 lines
2.7 KiB
Go
123 lines
2.7 KiB
Go
package log
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"os"
|
|
"runtime"
|
|
"strings"
|
|
"time"
|
|
|
|
log "github.com/Sirupsen/logrus"
|
|
"github.com/docker/docker/pkg/timeutils"
|
|
)
|
|
|
|
func init() {
|
|
log.SetOutput(os.Stderr)
|
|
log.SetLevel(log.InfoLevel)
|
|
if os.Getenv("DEBUG") != "" {
|
|
log.SetLevel(log.DebugLevel)
|
|
}
|
|
}
|
|
|
|
type priority int
|
|
|
|
const (
|
|
errorFormat = "[%s] [%s] %s:%d %s\n"
|
|
logFormat = "[%s] [%s] %s\n"
|
|
|
|
fatalPriority priority = iota
|
|
errorPriority
|
|
infoPriority
|
|
debugPriority
|
|
)
|
|
|
|
// A common interface to access the Fatal method of
|
|
// both testing.B and testing.T.
|
|
type Fataler interface {
|
|
Fatal(args ...interface{})
|
|
}
|
|
|
|
func (p priority) String() string {
|
|
switch p {
|
|
case fatalPriority:
|
|
return "fatal"
|
|
case errorPriority:
|
|
return "error"
|
|
case infoPriority:
|
|
return "info"
|
|
case debugPriority:
|
|
return "debug"
|
|
}
|
|
|
|
return ""
|
|
}
|
|
|
|
var DefaultLogger = Logger{Out: os.Stdout, Err: os.Stderr}
|
|
|
|
// Debug function, if the debug flag is set, then display. Do nothing otherwise
|
|
// If Docker is in damon mode, also send the debug info on the socket
|
|
func Debugf(format string, a ...interface{}) (int, error) {
|
|
return DefaultLogger.Debugf(format, a...)
|
|
}
|
|
|
|
func Infof(format string, a ...interface{}) (int, error) {
|
|
return DefaultLogger.Infof(format, a...)
|
|
}
|
|
|
|
func Errorf(format string, a ...interface{}) (int, error) {
|
|
return DefaultLogger.Errorf(format, a...)
|
|
}
|
|
|
|
func Fatal(a ...interface{}) {
|
|
DefaultLogger.Fatalf("%s", a...)
|
|
}
|
|
|
|
func Fatalf(format string, a ...interface{}) {
|
|
DefaultLogger.Fatalf(format, a...)
|
|
}
|
|
|
|
type Logger struct {
|
|
Err io.Writer
|
|
Out io.Writer
|
|
}
|
|
|
|
func (l Logger) Debugf(format string, a ...interface{}) (int, error) {
|
|
if os.Getenv("DEBUG") != "" {
|
|
return l.logf(l.Err, debugPriority, format, a...)
|
|
}
|
|
return 0, nil
|
|
}
|
|
|
|
func (l Logger) Infof(format string, a ...interface{}) (int, error) {
|
|
return l.logf(l.Out, infoPriority, format, a...)
|
|
}
|
|
|
|
func (l Logger) Errorf(format string, a ...interface{}) (int, error) {
|
|
return l.logf(l.Err, errorPriority, format, a...)
|
|
}
|
|
|
|
func (l Logger) Fatalf(format string, a ...interface{}) {
|
|
l.logf(l.Err, fatalPriority, format, a...)
|
|
os.Exit(1)
|
|
}
|
|
|
|
func (l Logger) logf(stream io.Writer, level priority, format string, a ...interface{}) (int, error) {
|
|
var prefix string
|
|
|
|
if level <= errorPriority || level == debugPriority {
|
|
// Retrieve the stack infos
|
|
_, file, line, ok := runtime.Caller(2)
|
|
if !ok {
|
|
file = "<unknown>"
|
|
line = -1
|
|
} else {
|
|
file = file[strings.LastIndex(file, "/")+1:]
|
|
}
|
|
prefix = fmt.Sprintf(errorFormat, time.Now().Format(timeutils.RFC3339NanoFixed), level.String(), file, line, format)
|
|
} else {
|
|
prefix = fmt.Sprintf(logFormat, time.Now().Format(timeutils.RFC3339NanoFixed), level.String(), format)
|
|
}
|
|
|
|
return fmt.Fprintf(stream, prefix, a...)
|
|
}
|