log.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  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. if err := logger.SetLogger(mode, config); err != nil {
  30. Fatal("Fail to set logger(%s): %v", mode, err)
  31. }
  32. }
  33. func Trace(format string, v ...interface{}) {
  34. for _, logger := range loggers {
  35. logger.Trace(format, v...)
  36. }
  37. }
  38. func Debug(format string, v ...interface{}) {
  39. for _, logger := range loggers {
  40. logger.Debug(format, v...)
  41. }
  42. }
  43. func Info(format string, v ...interface{}) {
  44. for _, logger := range loggers {
  45. logger.Info(format, v...)
  46. }
  47. }
  48. func Error(format string, v ...interface{}) {
  49. for _, logger := range loggers {
  50. logger.Error(format, v...)
  51. }
  52. }
  53. func Warn(format string, v ...interface{}) {
  54. for _, logger := range loggers {
  55. logger.Warn(format, v...)
  56. }
  57. }
  58. func Critical(format string, v ...interface{}) {
  59. for _, logger := range loggers {
  60. logger.Critical(format, v...)
  61. }
  62. }
  63. func Fatal(format string, v ...interface{}) {
  64. Error(format, v...)
  65. for _, l := range loggers {
  66. l.Close()
  67. }
  68. os.Exit(2)
  69. }