log.go 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. // Copyright 2014 The Gogs Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. // Package log is a wrapper of logs for short calling name.
  5. package log
  6. import (
  7. "os"
  8. "github.com/gogits/logs"
  9. )
  10. var (
  11. loggers []*logs.BeeLogger
  12. )
  13. func init() {
  14. NewLogger(0, "console", `{"level": 0}`)
  15. }
  16. func NewLogger(bufLen int64, mode, config string) {
  17. logger := logs.NewLogger(bufLen)
  18. isExist := false
  19. for _, l := range loggers {
  20. if l.Adapter == mode {
  21. isExist = true
  22. l = logger
  23. }
  24. }
  25. if !isExist {
  26. loggers = append(loggers, logger)
  27. }
  28. logger.SetLogFuncCallDepth(3)
  29. logger.SetLogger(mode, config)
  30. }
  31. func Trace(format string, v ...interface{}) {
  32. for _, logger := range loggers {
  33. logger.Trace(format, v...)
  34. }
  35. }
  36. func Debug(format string, v ...interface{}) {
  37. for _, logger := range loggers {
  38. logger.Debug(format, v...)
  39. }
  40. }
  41. func Info(format string, v ...interface{}) {
  42. for _, logger := range loggers {
  43. logger.Info(format, v...)
  44. }
  45. }
  46. func Error(format string, v ...interface{}) {
  47. for _, logger := range loggers {
  48. logger.Error(format, v...)
  49. }
  50. }
  51. func Warn(format string, v ...interface{}) {
  52. for _, logger := range loggers {
  53. logger.Warn(format, v...)
  54. }
  55. }
  56. func Critical(format string, v ...interface{}) {
  57. for _, logger := range loggers {
  58. logger.Critical(format, v...)
  59. }
  60. }
  61. func Fatal(format string, v ...interface{}) {
  62. Error(format, v...)
  63. for _, l := range loggers {
  64. l.Close()
  65. }
  66. os.Exit(2)
  67. }