| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187 | // Copyright 2015 The Xorm Authors. All rights reserved.// Use of this source code is governed by a BSD-style// license that can be found in the LICENSE file.package xormimport (	"fmt"	"io"	"log"	"github.com/go-xorm/core")// default log optionsconst (	DEFAULT_LOG_PREFIX = "[xorm]"	DEFAULT_LOG_FLAG   = log.Ldate | log.Lmicroseconds	DEFAULT_LOG_LEVEL  = core.LOG_DEBUG)var _ core.ILogger = DiscardLogger{}// DiscardLogger don't log implementation for core.ILoggertype DiscardLogger struct{}// Debug empty implementationfunc (DiscardLogger) Debug(v ...interface{}) {}// Debugf empty implementationfunc (DiscardLogger) Debugf(format string, v ...interface{}) {}// Error empty implementationfunc (DiscardLogger) Error(v ...interface{}) {}// Errorf empty implementationfunc (DiscardLogger) Errorf(format string, v ...interface{}) {}// Info empty implementationfunc (DiscardLogger) Info(v ...interface{}) {}// Infof empty implementationfunc (DiscardLogger) Infof(format string, v ...interface{}) {}// Warn empty implementationfunc (DiscardLogger) Warn(v ...interface{}) {}// Warnf empty implementationfunc (DiscardLogger) Warnf(format string, v ...interface{}) {}// Level empty implementationfunc (DiscardLogger) Level() core.LogLevel {	return core.LOG_UNKNOWN}// SetLevel empty implementationfunc (DiscardLogger) SetLevel(l core.LogLevel) {}// ShowSQL empty implementationfunc (DiscardLogger) ShowSQL(show ...bool) {}// IsShowSQL empty implementationfunc (DiscardLogger) IsShowSQL() bool {	return false}// SimpleLogger is the default implment of core.ILoggertype SimpleLogger struct {	DEBUG   *log.Logger	ERR     *log.Logger	INFO    *log.Logger	WARN    *log.Logger	level   core.LogLevel	showSQL bool}var _ core.ILogger = &SimpleLogger{}// NewSimpleLogger use a special io.Writer as logger outputfunc NewSimpleLogger(out io.Writer) *SimpleLogger {	return NewSimpleLogger2(out, DEFAULT_LOG_PREFIX, DEFAULT_LOG_FLAG)}// NewSimpleLogger2 let you customrize your logger prefix and flagfunc NewSimpleLogger2(out io.Writer, prefix string, flag int) *SimpleLogger {	return NewSimpleLogger3(out, prefix, flag, DEFAULT_LOG_LEVEL)}// NewSimpleLogger3 let you customrize your logger prefix and flag and logLevelfunc NewSimpleLogger3(out io.Writer, prefix string, flag int, l core.LogLevel) *SimpleLogger {	return &SimpleLogger{		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,	}}// Error implement core.ILoggerfunc (s *SimpleLogger) Error(v ...interface{}) {	if s.level <= core.LOG_ERR {		s.ERR.Output(2, fmt.Sprint(v...))	}	return}// Errorf implement core.ILoggerfunc (s *SimpleLogger) Errorf(format string, v ...interface{}) {	if s.level <= core.LOG_ERR {		s.ERR.Output(2, fmt.Sprintf(format, v...))	}	return}// Debug implement core.ILoggerfunc (s *SimpleLogger) Debug(v ...interface{}) {	if s.level <= core.LOG_DEBUG {		s.DEBUG.Output(2, fmt.Sprint(v...))	}	return}// Debugf implement core.ILoggerfunc (s *SimpleLogger) Debugf(format string, v ...interface{}) {	if s.level <= core.LOG_DEBUG {		s.DEBUG.Output(2, fmt.Sprintf(format, v...))	}	return}// Info implement core.ILoggerfunc (s *SimpleLogger) Info(v ...interface{}) {	if s.level <= core.LOG_INFO {		s.INFO.Output(2, fmt.Sprint(v...))	}	return}// Infof implement core.ILoggerfunc (s *SimpleLogger) Infof(format string, v ...interface{}) {	if s.level <= core.LOG_INFO {		s.INFO.Output(2, fmt.Sprintf(format, v...))	}	return}// Warn implement core.ILoggerfunc (s *SimpleLogger) Warn(v ...interface{}) {	if s.level <= core.LOG_WARNING {		s.WARN.Output(2, fmt.Sprint(v...))	}	return}// Warnf implement core.ILoggerfunc (s *SimpleLogger) Warnf(format string, v ...interface{}) {	if s.level <= core.LOG_WARNING {		s.WARN.Output(2, fmt.Sprintf(format, v...))	}	return}// Level implement core.ILoggerfunc (s *SimpleLogger) Level() core.LogLevel {	return s.level}// SetLevel implement core.ILoggerfunc (s *SimpleLogger) SetLevel(l core.LogLevel) {	s.level = l	return}// ShowSQL implement core.ILoggerfunc (s *SimpleLogger) ShowSQL(show ...bool) {	if len(show) == 0 {		s.showSQL = true		return	}	s.showSQL = show[0]}// IsShowSQL implement core.ILoggerfunc (s *SimpleLogger) IsShowSQL() bool {	return s.showSQL}
 |