logger.go 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. package logger
  2. import (
  3. "fmt"
  4. "log"
  5. )
  6. type LogLevel int
  7. const (
  8. LevelNone LogLevel = 0
  9. LevelError LogLevel = 1
  10. LevelWarn LogLevel = 2
  11. LevelInfo LogLevel = 3
  12. LevelVerbose LogLevel = 4
  13. LevelDebug LogLevel = 5
  14. )
  15. type Logger struct {
  16. Level LogLevel
  17. }
  18. func (l *Logger) printf(level string, str string, args ...interface{}) {
  19. log.Printf(fmt.Sprintf("[%s] %s", level, str), args...)
  20. }
  21. func (l *Logger) Fatal(str string, args ...interface{}) {
  22. log.Fatalf(str, args...)
  23. }
  24. func (l *Logger) Error(str string, args ...interface{}) {
  25. if l.Level >= LevelError {
  26. l.printf("error", str, args...)
  27. }
  28. }
  29. func (l *Logger) Warn(str string, args ...interface{}) {
  30. if l.Level >= LevelWarn {
  31. l.printf("warn", str, args...)
  32. }
  33. }
  34. func (l *Logger) Info(str string, args ...interface{}) {
  35. if l.Level >= LevelInfo {
  36. l.printf("info", str, args...)
  37. }
  38. }
  39. func (l *Logger) Verbose(str string, args ...interface{}) {
  40. if l.Level >= LevelVerbose {
  41. l.printf("verbose", str, args...)
  42. }
  43. }
  44. func (l *Logger) Debug(str string, args ...interface{}) {
  45. if l.Level >= LevelDebug {
  46. l.printf("debug", str, args...)
  47. }
  48. }
  49. func CreateLogger(level LogLevel) *Logger {
  50. var l = Logger{
  51. Level: level,
  52. }
  53. return &l
  54. }