2014-02-11 17:35:26 +00:00
|
|
|
package xorm
|
|
|
|
|
|
|
|
import (
|
2014-08-07 21:05:45 +00:00
|
|
|
"fmt"
|
2014-02-11 17:35:26 +00:00
|
|
|
"io"
|
|
|
|
"log"
|
2014-08-21 03:40:55 +00:00
|
|
|
|
|
|
|
"github.com/go-xorm/core"
|
2014-08-20 01:38:52 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
DEFAULT_LOG_PREFIX = "[xorm]"
|
|
|
|
DEFAULT_LOG_FLAG = log.Ldate | log.Lmicroseconds
|
2014-08-20 02:37:52 +00:00
|
|
|
DEFAULT_LOG_LEVEL = core.LOG_DEBUG
|
2014-08-20 01:38:52 +00:00
|
|
|
)
|
2014-02-11 17:35:26 +00:00
|
|
|
|
|
|
|
type SimpleLogger struct {
|
2014-08-20 02:37:52 +00:00
|
|
|
DEBUG *log.Logger
|
|
|
|
ERR *log.Logger
|
|
|
|
INFO *log.Logger
|
|
|
|
WARN *log.Logger
|
|
|
|
level core.LogLevel
|
2014-02-11 17:35:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewSimpleLogger(out io.Writer) *SimpleLogger {
|
2014-08-20 01:38:52 +00:00
|
|
|
return NewSimpleLogger2(out, DEFAULT_LOG_PREFIX, DEFAULT_LOG_FLAG)
|
2014-02-11 17:35:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewSimpleLogger2(out io.Writer, prefix string, flag int) *SimpleLogger {
|
2014-08-20 01:38:52 +00:00
|
|
|
return NewSimpleLogger3(out, prefix, flag, DEFAULT_LOG_LEVEL)
|
|
|
|
}
|
|
|
|
|
2014-08-20 02:37:52 +00:00
|
|
|
func NewSimpleLogger3(out io.Writer, prefix string, flag int, l core.LogLevel) *SimpleLogger {
|
2014-02-11 17:35:26 +00:00
|
|
|
return &SimpleLogger{
|
2014-08-20 02:37:52 +00:00
|
|
|
DEBUG: log.New(out, fmt.Sprintf("%s [debug] ", prefix), flag),
|
|
|
|
ERR: log.New(out, fmt.Sprintf("%s [error] ", prefix), flag),
|
|
|
|
INFO: log.New(out, fmt.Sprintf("%s [info] ", prefix), flag),
|
|
|
|
WARN: log.New(out, fmt.Sprintf("%s [warn] ", prefix), flag),
|
|
|
|
level: l,
|
2014-08-07 21:05:45 +00:00
|
|
|
}
|
2014-02-11 17:35:26 +00:00
|
|
|
}
|
|
|
|
|
2014-08-20 02:37:52 +00:00
|
|
|
func (s *SimpleLogger) Err(v ...interface{}) (err error) {
|
|
|
|
if s.level > core.LOG_OFF && s.level <= core.LOG_ERR {
|
|
|
|
s.ERR.Println(v...)
|
2014-08-20 01:38:52 +00:00
|
|
|
}
|
2014-02-11 17:35:26 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2014-08-20 02:37:52 +00:00
|
|
|
func (s *SimpleLogger) Errf(format string, v ...interface{}) (err error) {
|
|
|
|
if s.level > core.LOG_OFF && s.level <= core.LOG_ERR {
|
|
|
|
s.ERR.Printf(format, v...)
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *SimpleLogger) Debug(v ...interface{}) (err error) {
|
|
|
|
if s.level > core.LOG_OFF && s.level <= core.LOG_DEBUG {
|
|
|
|
s.DEBUG.Println(v...)
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *SimpleLogger) Debugf(format string, v ...interface{}) (err error) {
|
|
|
|
if s.level > core.LOG_OFF && s.level >= core.LOG_DEBUG {
|
|
|
|
s.DEBUG.Printf(format, v...)
|
|
|
|
}
|
2014-02-11 17:35:26 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2014-08-20 02:37:52 +00:00
|
|
|
func (s *SimpleLogger) Info(v ...interface{}) (err error) {
|
|
|
|
if s.level > core.LOG_OFF && s.level >= core.LOG_INFO {
|
|
|
|
s.INFO.Println(v...)
|
2014-08-20 01:38:52 +00:00
|
|
|
}
|
2014-02-11 17:35:26 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2014-08-20 02:37:52 +00:00
|
|
|
func (s *SimpleLogger) Infof(format string, v ...interface{}) (err error) {
|
|
|
|
if s.level > core.LOG_OFF && s.level >= core.LOG_INFO {
|
|
|
|
s.INFO.Printf(format, v...)
|
2014-08-20 01:38:52 +00:00
|
|
|
}
|
2014-02-11 17:35:26 +00:00
|
|
|
return
|
|
|
|
}
|
2014-08-20 02:37:52 +00:00
|
|
|
|
|
|
|
func (s *SimpleLogger) Warning(v ...interface{}) (err error) {
|
|
|
|
if s.level > core.LOG_OFF && s.level >= core.LOG_WARNING {
|
|
|
|
s.WARN.Println(v...)
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *SimpleLogger) Warningf(format string, v ...interface{}) (err error) {
|
|
|
|
if s.level > core.LOG_OFF && s.level >= core.LOG_WARNING {
|
|
|
|
s.WARN.Printf(format, v...)
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *SimpleLogger) Level() core.LogLevel {
|
|
|
|
return s.level
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *SimpleLogger) SetLevel(l core.LogLevel) (err error) {
|
|
|
|
s.level = l
|
|
|
|
return
|
|
|
|
}
|