log.go 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. package log
  2. import (
  3. "fmt"
  4. "log"
  5. "os"
  6. )
  7. const (
  8. DebugLevel = LogLevel(0)
  9. InfoLevel = LogLevel(1)
  10. WarningLevel = LogLevel(2)
  11. ErrorLevel = LogLevel(3)
  12. )
  13. type logger interface {
  14. WriteLog(prefix, format string, v ...interface{})
  15. }
  16. type noOpLogger struct {
  17. }
  18. func (this *noOpLogger) WriteLog(prefix, format string, v ...interface{}) {
  19. // Swallow
  20. }
  21. type streamLogger struct {
  22. logger *log.Logger
  23. }
  24. func (this *streamLogger) WriteLog(prefix, format string, v ...interface{}) {
  25. var data string
  26. if v == nil || len(v) == 0 {
  27. data = format
  28. } else {
  29. data = fmt.Sprintf(format, v...)
  30. }
  31. this.logger.Println(prefix + data)
  32. }
  33. var (
  34. noOpLoggerInstance logger = &noOpLogger{}
  35. streamLoggerInstance logger = &streamLogger{
  36. logger: log.New(os.Stdout, "", log.Ldate|log.Ltime),
  37. }
  38. debugLogger = noOpLoggerInstance
  39. infoLogger = noOpLoggerInstance
  40. warningLogger = noOpLoggerInstance
  41. errorLogger = noOpLoggerInstance
  42. )
  43. type LogLevel int
  44. func SetLogLevel(level LogLevel) {
  45. debugLogger = noOpLoggerInstance
  46. if level <= DebugLevel {
  47. debugLogger = streamLoggerInstance
  48. }
  49. infoLogger = noOpLoggerInstance
  50. if level <= InfoLevel {
  51. infoLogger = streamLoggerInstance
  52. }
  53. warningLogger = noOpLoggerInstance
  54. if level <= WarningLevel {
  55. warningLogger = streamLoggerInstance
  56. }
  57. errorLogger = noOpLoggerInstance
  58. if level <= ErrorLevel {
  59. errorLogger = streamLoggerInstance
  60. }
  61. }
  62. // Debug outputs a debug log with given format and optional arguments.
  63. func Debug(format string, v ...interface{}) {
  64. debugLogger.WriteLog("[Debug]", format, v...)
  65. }
  66. // Info outputs an info log with given format and optional arguments.
  67. func Info(format string, v ...interface{}) {
  68. infoLogger.WriteLog("[Info]", format, v...)
  69. }
  70. // Warning outputs a warning log with given format and optional arguments.
  71. func Warning(format string, v ...interface{}) {
  72. warningLogger.WriteLog("[Warning]", format, v...)
  73. }
  74. // Error outputs an error log with given format and optional arguments.
  75. func Error(format string, v ...interface{}) {
  76. errorLogger.WriteLog("[Error]", format, v...)
  77. }