2022-06-29 21:12:30 +00:00
|
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
|
2022-06-29 22:57:03 +00:00
|
|
|
package logawl
|
|
|
|
|
|
|
|
import (
|
2022-08-04 01:09:49 +00:00
|
|
|
"errors"
|
2022-06-29 22:57:03 +00:00
|
|
|
"io"
|
|
|
|
"sync"
|
|
|
|
"sync/atomic"
|
|
|
|
)
|
|
|
|
|
2022-07-26 00:32:31 +00:00
|
|
|
type (
|
2022-08-11 07:25:36 +00:00
|
|
|
// Level is the logging level.
|
|
|
|
Level int32
|
|
|
|
|
|
|
|
// Logger is the overall logger.
|
2022-07-26 00:32:31 +00:00
|
|
|
Logger struct {
|
2022-08-11 07:25:36 +00:00
|
|
|
Out io.Writer
|
|
|
|
Prefix string
|
|
|
|
buf []byte
|
2022-07-26 00:32:31 +00:00
|
|
|
Mu sync.Mutex
|
|
|
|
Level Level
|
2022-08-04 01:09:49 +00:00
|
|
|
isDiscard int32
|
2022-07-26 00:32:31 +00:00
|
|
|
}
|
|
|
|
)
|
2022-06-29 22:57:03 +00:00
|
|
|
|
2022-08-11 07:25:36 +00:00
|
|
|
// SetLevel stores whatever input value is in mem address of l.level.
|
2022-09-24 23:11:09 +00:00
|
|
|
func (logger *Logger) SetLevel(level Level) {
|
|
|
|
atomic.StoreInt32((*int32)(&logger.Level), int32(level))
|
2022-06-29 22:57:03 +00:00
|
|
|
}
|
|
|
|
|
2022-08-11 07:25:36 +00:00
|
|
|
// GetLevel gets the logger level.
|
2022-09-24 23:11:09 +00:00
|
|
|
func (logger *Logger) GetLevel() Level {
|
|
|
|
return logger.level()
|
2022-06-29 22:57:03 +00:00
|
|
|
}
|
|
|
|
|
2022-07-26 00:32:31 +00:00
|
|
|
// Retrieves whatever was stored in mem address of l.level.
|
2022-09-24 23:11:09 +00:00
|
|
|
func (logger *Logger) level() Level {
|
|
|
|
return Level(atomic.LoadInt32((*int32)(&logger.Level)))
|
2022-06-29 22:57:03 +00:00
|
|
|
}
|
|
|
|
|
2022-08-11 07:25:36 +00:00
|
|
|
// UnMarshalLevel unmarshalls the int value of level for writing the header.
|
2022-09-24 23:11:09 +00:00
|
|
|
func (logger *Logger) UnMarshalLevel(lv Level) (string, error) {
|
2022-06-29 22:57:03 +00:00
|
|
|
switch lv {
|
2022-09-04 23:28:47 +00:00
|
|
|
case ErrLevel:
|
2022-06-29 22:57:03 +00:00
|
|
|
return "ERROR ", nil
|
2022-09-04 23:28:47 +00:00
|
|
|
case WarnLevel:
|
2022-07-26 00:32:31 +00:00
|
|
|
return "WARN ", nil
|
2022-09-04 23:28:47 +00:00
|
|
|
case InfoLevel:
|
2022-06-29 22:57:03 +00:00
|
|
|
return "INFO ", nil
|
2022-09-04 23:28:47 +00:00
|
|
|
case DebugLevel:
|
2022-06-29 22:57:03 +00:00
|
|
|
return "DEBUG ", nil
|
|
|
|
}
|
2022-08-11 07:25:36 +00:00
|
|
|
|
2022-08-04 01:09:49 +00:00
|
|
|
return "", errInvalidLevel
|
2022-06-29 22:57:03 +00:00
|
|
|
}
|
|
|
|
|
2022-08-11 07:25:36 +00:00
|
|
|
// IsLevel returns true if the logger level is above the level given.
|
2022-09-24 23:11:09 +00:00
|
|
|
func (logger *Logger) IsLevel(level Level) bool {
|
|
|
|
return logger.level() >= level
|
2022-06-29 22:57:03 +00:00
|
|
|
}
|
|
|
|
|
2022-08-11 07:25:36 +00:00
|
|
|
// AllLevels is an array of all valid log levels.
|
2022-06-29 22:57:03 +00:00
|
|
|
var AllLevels = []Level{
|
2022-07-26 00:32:31 +00:00
|
|
|
ErrLevel,
|
|
|
|
WarnLevel,
|
2022-06-29 22:57:03 +00:00
|
|
|
InfoLevel,
|
|
|
|
DebugLevel,
|
|
|
|
}
|
|
|
|
|
|
|
|
const (
|
2022-08-11 07:25:36 +00:00
|
|
|
// ErrLevel is the fatal (error) log level.
|
2022-07-26 00:32:31 +00:00
|
|
|
ErrLevel Level = iota
|
2022-06-29 22:57:03 +00:00
|
|
|
|
2022-08-11 07:25:36 +00:00
|
|
|
// WarnLevel is for warning logs.
|
|
|
|
//
|
|
|
|
// Example: when one setting implies another, when a request fails but is retried.
|
2022-07-26 00:32:31 +00:00
|
|
|
WarnLevel
|
2022-06-29 22:57:03 +00:00
|
|
|
|
2022-08-11 07:25:36 +00:00
|
|
|
// InfoLevel is for saying what is going on when.
|
|
|
|
// This is essentially the "verbose" option.
|
|
|
|
//
|
|
|
|
// When in doubt, use info.
|
2022-06-29 22:57:03 +00:00
|
|
|
InfoLevel
|
2022-08-11 07:25:36 +00:00
|
|
|
|
|
|
|
// DebugLevel is for spewing debug structs/interfaces.
|
2022-06-29 22:57:03 +00:00
|
|
|
DebugLevel
|
|
|
|
)
|
2022-08-04 01:09:49 +00:00
|
|
|
|
|
|
|
var errInvalidLevel = errors.New("invalid log level")
|