log.go 2.1 KB

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