2014-02-13 03:54:09 +08:00
|
|
|
// Copyright 2014 The Gogs Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a MIT-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
// Package log is a wrapper of logs for short calling name.
|
|
|
|
package log
|
|
|
|
|
|
|
|
import (
|
2014-05-26 08:11:25 +08:00
|
|
|
"os"
|
|
|
|
|
2014-02-13 03:54:09 +08:00
|
|
|
"github.com/gogits/logs"
|
|
|
|
)
|
|
|
|
|
2014-03-25 19:47:04 +08:00
|
|
|
var (
|
2014-05-12 02:37:12 +08:00
|
|
|
loggers []*logs.BeeLogger
|
2014-03-25 19:47:04 +08:00
|
|
|
)
|
2014-02-13 03:54:09 +08:00
|
|
|
|
2014-03-24 00:32:16 +08:00
|
|
|
func init() {
|
2014-04-01 12:07:25 +08:00
|
|
|
NewLogger(0, "console", `{"level": 0}`)
|
2014-03-24 00:32:16 +08:00
|
|
|
}
|
|
|
|
|
2014-03-19 16:08:25 +08:00
|
|
|
func NewLogger(bufLen int64, mode, config string) {
|
2014-05-12 02:37:12 +08:00
|
|
|
logger := logs.NewLogger(bufLen)
|
|
|
|
|
|
|
|
isExist := false
|
|
|
|
for _, l := range loggers {
|
|
|
|
if l.Adapter == mode {
|
|
|
|
isExist = true
|
|
|
|
l = logger
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if !isExist {
|
|
|
|
loggers = append(loggers, logger)
|
|
|
|
}
|
2014-04-11 04:36:50 +08:00
|
|
|
logger.SetLogFuncCallDepth(3)
|
2014-06-20 12:25:23 +08:00
|
|
|
if err := logger.SetLogger(mode, config); err != nil {
|
|
|
|
Fatal("Fail to set logger(%s): %v", mode, err)
|
|
|
|
}
|
2014-02-13 03:54:09 +08:00
|
|
|
}
|
|
|
|
|
2014-02-19 06:48:02 +08:00
|
|
|
func Trace(format string, v ...interface{}) {
|
2014-05-12 02:37:12 +08:00
|
|
|
for _, logger := range loggers {
|
|
|
|
logger.Trace(format, v...)
|
|
|
|
}
|
2014-02-19 06:48:02 +08:00
|
|
|
}
|
|
|
|
|
2014-03-24 00:16:17 +08:00
|
|
|
func Debug(format string, v ...interface{}) {
|
2014-05-12 02:37:12 +08:00
|
|
|
for _, logger := range loggers {
|
|
|
|
logger.Debug(format, v...)
|
|
|
|
}
|
2014-03-24 00:16:17 +08:00
|
|
|
}
|
|
|
|
|
2014-02-13 03:54:09 +08:00
|
|
|
func Info(format string, v ...interface{}) {
|
2014-05-12 02:37:12 +08:00
|
|
|
for _, logger := range loggers {
|
|
|
|
logger.Info(format, v...)
|
|
|
|
}
|
2014-02-13 03:54:09 +08:00
|
|
|
}
|
2014-02-19 06:31:16 +08:00
|
|
|
|
|
|
|
func Error(format string, v ...interface{}) {
|
2014-05-12 02:37:12 +08:00
|
|
|
for _, logger := range loggers {
|
|
|
|
logger.Error(format, v...)
|
|
|
|
}
|
2014-02-19 06:31:16 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func Warn(format string, v ...interface{}) {
|
2014-05-12 02:37:12 +08:00
|
|
|
for _, logger := range loggers {
|
|
|
|
logger.Warn(format, v...)
|
|
|
|
}
|
2014-02-19 06:31:16 +08:00
|
|
|
}
|
2014-02-19 06:48:02 +08:00
|
|
|
|
|
|
|
func Critical(format string, v ...interface{}) {
|
2014-05-12 02:37:12 +08:00
|
|
|
for _, logger := range loggers {
|
|
|
|
logger.Critical(format, v...)
|
|
|
|
}
|
2014-02-19 06:48:02 +08:00
|
|
|
}
|
2014-05-26 08:11:25 +08:00
|
|
|
|
|
|
|
func Fatal(format string, v ...interface{}) {
|
|
|
|
Error(format, v...)
|
|
|
|
for _, l := range loggers {
|
|
|
|
l.Close()
|
|
|
|
}
|
|
|
|
os.Exit(2)
|
|
|
|
}
|