1 Star 0 Fork 12

kuraudo/logit

forked from 水不要鱼/logit 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
option.go 7.36 KB
一键复制 编辑 原始数据 按行查看 历史
水不要鱼 提交于 2022-02-08 14:53 . 修复若干问题
// Copyright 2021 Ye Zi Jie. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
// Author: FishGoddess
// Email: fishgoddess@qq.com
// Created at 2021/07/01 23:01:38
package logit
import (
"io"
"time"
"github.com/go-logit/logit/core/appender"
"github.com/go-logit/logit/core/writer"
)
// Option is a function that applies to logger.
type Option func(logger *Logger)
// options stores all provided options.
type options struct{}
// Options returns all options provided.
func Options() *options {
return (*options)(nil)
}
// WithDebugLevel returns an option which sets logger to debug level.
func (o *options) WithDebugLevel() Option {
return func(logger *Logger) {
logger.level = debugLevel
}
}
// WithInfoLevel returns an option which sets logger to info level.
func (o *options) WithInfoLevel() Option {
return func(logger *Logger) {
logger.level = infoLevel
}
}
// WithWarnLevel returns an option which sets logger to warn level.
func (o *options) WithWarnLevel() Option {
return func(logger *Logger) {
logger.level = warnLevel
}
}
// WithErrorLevel returns an option which sets logger to error level.
func (o *options) WithErrorLevel() Option {
return func(logger *Logger) {
logger.level = errorLevel
}
}
// WithOffLevel returns an option which sets logger to off level.
func (o *options) WithOffLevel() Option {
return func(logger *Logger) {
logger.level = offLevel
}
}
// WithAppender returns an option which sets logger's appender to a new one.
func (o *options) WithAppender(appender appender.Appender) Option {
return func(logger *Logger) {
logger.debugAppender = appender
logger.infoAppender = appender
logger.warnAppender = appender
logger.errorAppender = appender
logger.printAppender = appender
}
}
// WithDebugAppender returns an option which sets logger's debug appender to a new one.
func (o *options) WithDebugAppender(appender appender.Appender) Option {
return func(logger *Logger) {
logger.debugAppender = appender
}
}
// WithInfoAppender returns an option which sets logger's info appender to a new one.
func (o *options) WithInfoAppender(appender appender.Appender) Option {
return func(logger *Logger) {
logger.infoAppender = appender
}
}
// WithWarnAppender returns an option which sets logger's warn appender to a new one.
func (o *options) WithWarnAppender(appender appender.Appender) Option {
return func(logger *Logger) {
logger.warnAppender = appender
}
}
// WithErrorAppender returns an option which sets logger's error appender to a new one.
func (o *options) WithErrorAppender(appender appender.Appender) Option {
return func(logger *Logger) {
logger.errorAppender = appender
}
}
// WithPrintAppender returns an option which sets logger's print appender to a new one.
func (o *options) WithPrintAppender(appender appender.Appender) Option {
return func(logger *Logger) {
logger.printAppender = appender
}
}
// WithWriter returns an option which sets logger's writer to a new one.
func (o *options) WithWriter(w io.Writer, buffered bool) Option {
return func(logger *Logger) {
var wr writer.Writer
if buffered {
wr = writer.Buffered(w)
} else {
wr = writer.Wrapped(w)
}
logger.debugWriter = wr
logger.infoWriter = wr
logger.warnWriter = wr
logger.errorWriter = wr
logger.printWriter = wr
}
}
// WithDebugWriter returns an option which sets logger's debug writer to a new one.
func (o *options) WithDebugWriter(w io.Writer, buffered bool) Option {
return func(logger *Logger) {
if buffered {
logger.debugWriter = writer.Buffered(w)
} else {
logger.debugWriter = writer.Wrapped(w)
}
}
}
// WithInfoWriter returns an option which sets logger's info writer to a new one.
func (o *options) WithInfoWriter(w io.Writer, buffered bool) Option {
return func(logger *Logger) {
if buffered {
logger.infoWriter = writer.Buffered(w)
} else {
logger.infoWriter = writer.Wrapped(w)
}
}
}
// WithWarnWriter returns an option which sets logger's warn writer to a new one.
func (o *options) WithWarnWriter(w io.Writer, buffered bool) Option {
return func(logger *Logger) {
if buffered {
logger.warnWriter = writer.Buffered(w)
} else {
logger.warnWriter = writer.Wrapped(w)
}
}
}
// WithErrorWriter returns an option which sets logger's error writer to a new one.
func (o *options) WithErrorWriter(w io.Writer, buffered bool) Option {
return func(logger *Logger) {
if buffered {
logger.errorWriter = writer.Buffered(w)
} else {
logger.errorWriter = writer.Wrapped(w)
}
}
}
// WithPrintWriter returns an option which sets logger's print writer to a new one.
func (o *options) WithPrintWriter(w io.Writer, buffered bool) Option {
return func(logger *Logger) {
if buffered {
logger.printWriter = writer.Buffered(w)
} else {
logger.printWriter = writer.Wrapped(w)
}
}
}
// WithPid returns an option which lets logs carry pid information.
func (o *options) WithPid() Option {
return func(logger *Logger) {
logger.needPid = true
}
}
// WithCaller returns an option which lets logs carry caller information.
func (o *options) WithCaller() Option {
return func(logger *Logger) {
logger.needCaller = true
}
}
// WithMsgKey returns an option which sets logger's msgKey to a new one.
func (o *options) WithMsgKey(key string) Option {
return func(logger *Logger) {
logger.msgKey = key
}
}
// WithTimeKey returns an option which sets logger's timeKey to a new one.
func (o *options) WithTimeKey(key string) Option {
return func(logger *Logger) {
logger.timeKey = key
}
}
// WithLevelKey returns an option which sets logger's levelKey to a new one.
func (o *options) WithLevelKey(key string) Option {
return func(logger *Logger) {
logger.levelKey = key
}
}
// WithPidKey returns an option which sets logger's pidKey to a new one.
func (o *options) WithPidKey(key string) Option {
return func(logger *Logger) {
logger.pidKey = key
}
}
// WithFileKey returns an option which sets logger's fileKey to a new one.
func (o *options) WithFileKey(key string) Option {
return func(logger *Logger) {
logger.fileKey = key
}
}
// WithLineKey returns an option which sets logger's lineKey to a new one.
func (o *options) WithLineKey(key string) Option {
return func(logger *Logger) {
logger.lineKey = key
}
}
// WithTimeFormat returns an option which sets format of time in logs.
func (o *options) WithTimeFormat(format string) Option {
return func(logger *Logger) {
logger.timeFormat = format
}
}
// WithAutoFlush returns an option which do flush automatically at fixed frequency.
func (o *options) WithAutoFlush(frequency time.Duration) Option {
return func(logger *Logger) {
go func() {
ticker := time.NewTicker(frequency)
select {
case <-ticker.C:
logger.Flush()
}
}()
}
}
// WithCallerDepth returns an option which sets caller depth in logs.
func (o *options) WithCallerDepth(callerDepth int) Option {
return func(logger *Logger) {
logger.callerDepth = callerDepth
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/gasho/logit.git
git@gitee.com:gasho/logit.git
gasho
logit
logit
master

搜索帮助