mirror of
https://gitee.com/johng/gf.git
synced 2024-11-30 03:07:45 +08:00
76 lines
2.4 KiB
Go
76 lines
2.4 KiB
Go
// Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
|
|
//
|
|
// This Source Code Form is subject to the terms of the MIT License.
|
|
// If a copy of the MIT was not distributed with this file,
|
|
// You can obtain one at https://github.com/gogf/gf.
|
|
|
|
// Package glog implements powerful and easy-to-use leveled logging functionality.
|
|
package glog
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/gogf/gf/v2/internal/command"
|
|
"github.com/gogf/gf/v2/os/grpool"
|
|
"github.com/gogf/gf/v2/util/gconv"
|
|
)
|
|
|
|
// ILogger is the API interface for logger.
|
|
type ILogger interface {
|
|
Print(ctx context.Context, v ...interface{})
|
|
Printf(ctx context.Context, format string, v ...interface{})
|
|
Debug(ctx context.Context, v ...interface{})
|
|
Debugf(ctx context.Context, format string, v ...interface{})
|
|
Info(ctx context.Context, v ...interface{})
|
|
Infof(ctx context.Context, format string, v ...interface{})
|
|
Notice(ctx context.Context, v ...interface{})
|
|
Noticef(ctx context.Context, format string, v ...interface{})
|
|
Warning(ctx context.Context, v ...interface{})
|
|
Warningf(ctx context.Context, format string, v ...interface{})
|
|
Error(ctx context.Context, v ...interface{})
|
|
Errorf(ctx context.Context, format string, v ...interface{})
|
|
Critical(ctx context.Context, v ...interface{})
|
|
Criticalf(ctx context.Context, format string, v ...interface{})
|
|
Panic(ctx context.Context, v ...interface{})
|
|
Panicf(ctx context.Context, format string, v ...interface{})
|
|
Fatal(ctx context.Context, v ...interface{})
|
|
Fatalf(ctx context.Context, format string, v ...interface{})
|
|
}
|
|
|
|
const (
|
|
commandEnvKeyForDebug = "gf.glog.debug"
|
|
)
|
|
|
|
var (
|
|
// Ensure Logger implements ILogger.
|
|
_ ILogger = &Logger{}
|
|
|
|
// Default logger object, for package method usage.
|
|
defaultLogger = New()
|
|
|
|
// Goroutine pool for async logging output.
|
|
// It uses only one asynchronous worker to ensure log sequence.
|
|
asyncPool = grpool.New(1)
|
|
|
|
// defaultDebug enables debug level or not in default,
|
|
// which can be configured using command option or system environment.
|
|
defaultDebug = true
|
|
)
|
|
|
|
func init() {
|
|
defaultDebug = gconv.Bool(command.GetOptWithEnv(commandEnvKeyForDebug, "true"))
|
|
SetDebug(defaultDebug)
|
|
}
|
|
|
|
// DefaultLogger returns the default logger.
|
|
func DefaultLogger() *Logger {
|
|
return defaultLogger
|
|
}
|
|
|
|
// SetDefaultLogger sets the default logger for package glog.
|
|
// Note that there might be concurrent safety issue if calls this function
|
|
// in different goroutines.
|
|
func SetDefaultLogger(l *Logger) {
|
|
defaultLogger = l
|
|
}
|