logger.go 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. // Copyright 2015 The Xorm Authors. All rights reserved.
  2. // Use of this source code is governed by a BSD-style
  3. // license that can be found in the LICENSE file.
  4. package xorm
  5. import (
  6. "fmt"
  7. "io"
  8. "log"
  9. "github.com/xormplus/core"
  10. )
  11. const (
  12. DEFAULT_LOG_PREFIX = "[xorm]"
  13. DEFAULT_LOG_FLAG = log.Ldate | log.Lmicroseconds
  14. DEFAULT_LOG_LEVEL = core.LOG_DEBUG
  15. )
  16. var _ core.ILogger = DiscardLogger{}
  17. type DiscardLogger struct{}
  18. func (DiscardLogger) Debug(v ...interface{}) {}
  19. func (DiscardLogger) Debugf(format string, v ...interface{}) {}
  20. func (DiscardLogger) Error(v ...interface{}) {}
  21. func (DiscardLogger) Errorf(format string, v ...interface{}) {}
  22. func (DiscardLogger) Info(v ...interface{}) {}
  23. func (DiscardLogger) Infof(format string, v ...interface{}) {}
  24. func (DiscardLogger) Warn(v ...interface{}) {}
  25. func (DiscardLogger) Warnf(format string, v ...interface{}) {}
  26. func (DiscardLogger) Level() core.LogLevel {
  27. return core.LOG_UNKNOWN
  28. }
  29. func (DiscardLogger) SetLevel(l core.LogLevel) {}
  30. func (DiscardLogger) ShowSQL(show ...bool) {}
  31. func (DiscardLogger) IsShowSQL() bool {
  32. return false
  33. }
  34. // SimpleLogger is the default implment of core.ILogger
  35. type SimpleLogger struct {
  36. DEBUG *log.Logger
  37. ERR *log.Logger
  38. INFO *log.Logger
  39. WARN *log.Logger
  40. level core.LogLevel
  41. showSQL bool
  42. }
  43. var _ core.ILogger = &SimpleLogger{}
  44. // NewSimpleLogger use a special io.Writer as logger output
  45. func NewSimpleLogger(out io.Writer) *SimpleLogger {
  46. return NewSimpleLogger2(out, DEFAULT_LOG_PREFIX, DEFAULT_LOG_FLAG)
  47. }
  48. // NewSimpleLogger2 let you customrize your logger prefix and flag
  49. func NewSimpleLogger2(out io.Writer, prefix string, flag int) *SimpleLogger {
  50. return NewSimpleLogger3(out, prefix, flag, DEFAULT_LOG_LEVEL)
  51. }
  52. // NewSimpleLogger3 let you customrize your logger prefix and flag and logLevel
  53. func NewSimpleLogger3(out io.Writer, prefix string, flag int, l core.LogLevel) *SimpleLogger {
  54. return &SimpleLogger{
  55. DEBUG: log.New(out, fmt.Sprintf("%s [debug] ", prefix), flag),
  56. ERR: log.New(out, fmt.Sprintf("%s [error] ", prefix), flag),
  57. INFO: log.New(out, fmt.Sprintf("%s [info] ", prefix), flag),
  58. WARN: log.New(out, fmt.Sprintf("%s [warn] ", prefix), flag),
  59. level: l,
  60. }
  61. }
  62. // Error implement core.ILogger
  63. func (s *SimpleLogger) Error(v ...interface{}) {
  64. if s.level <= core.LOG_ERR {
  65. s.ERR.Output(2, fmt.Sprint(v...))
  66. }
  67. return
  68. }
  69. // Errorf implement core.ILogger
  70. func (s *SimpleLogger) Errorf(format string, v ...interface{}) {
  71. if s.level <= core.LOG_ERR {
  72. s.ERR.Output(2, fmt.Sprintf(format, v...))
  73. }
  74. return
  75. }
  76. // Debug implement core.ILogger
  77. func (s *SimpleLogger) Debug(v ...interface{}) {
  78. if s.level <= core.LOG_DEBUG {
  79. s.DEBUG.Output(2, fmt.Sprint(v...))
  80. }
  81. return
  82. }
  83. // Debugf implement core.ILogger
  84. func (s *SimpleLogger) Debugf(format string, v ...interface{}) {
  85. if s.level <= core.LOG_DEBUG {
  86. s.DEBUG.Output(2, fmt.Sprintf(format, v...))
  87. }
  88. return
  89. }
  90. // Info implement core.ILogger
  91. func (s *SimpleLogger) Info(v ...interface{}) {
  92. if s.level <= core.LOG_INFO {
  93. s.INFO.Output(2, fmt.Sprint(v...))
  94. }
  95. return
  96. }
  97. // Infof implement core.ILogger
  98. func (s *SimpleLogger) Infof(format string, v ...interface{}) {
  99. if s.level <= core.LOG_INFO {
  100. s.INFO.Output(2, fmt.Sprintf(format, v...))
  101. }
  102. return
  103. }
  104. // Warn implement core.ILogger
  105. func (s *SimpleLogger) Warn(v ...interface{}) {
  106. if s.level <= core.LOG_WARNING {
  107. s.WARN.Output(2, fmt.Sprint(v...))
  108. }
  109. return
  110. }
  111. // Warnf implement core.ILogger
  112. func (s *SimpleLogger) Warnf(format string, v ...interface{}) {
  113. if s.level <= core.LOG_WARNING {
  114. s.WARN.Output(2, fmt.Sprintf(format, v...))
  115. }
  116. return
  117. }
  118. // Level implement core.ILogger
  119. func (s *SimpleLogger) Level() core.LogLevel {
  120. return s.level
  121. }
  122. // SetLevel implement core.ILogger
  123. func (s *SimpleLogger) SetLevel(l core.LogLevel) {
  124. s.level = l
  125. return
  126. }
  127. // ShowSQL implement core.ILogger
  128. func (s *SimpleLogger) ShowSQL(show ...bool) {
  129. if len(show) == 0 {
  130. s.showSQL = true
  131. return
  132. }
  133. s.showSQL = show[0]
  134. }
  135. // IsShowSQL implement core.ILogger
  136. func (s *SimpleLogger) IsShowSQL() bool {
  137. return s.showSQL
  138. }