summaryrefslogtreecommitdiff
path: root/vendor/codeberg.org/gruf/go-logger/v2/level/levels.go
blob: 1804bdb23463834f229891f3a2cdfa1c30d78f21 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
package level

// LEVEL defines a level of logging.
type LEVEL uint8

// Default levels of logging.
const (
	UNSET LEVEL = 0
	PANIC LEVEL = 1
	FATAL LEVEL = 50
	ERROR LEVEL = 100
	WARN  LEVEL = 150
	INFO  LEVEL = 200
	DEBUG LEVEL = 250
	TRACE LEVEL = 254
	ALL   LEVEL = ^LEVEL(0)
)

// CanLog returns whether an incoming log of 'lvl' can be logged against receiving level.
func (loglvl LEVEL) CanLog(lvl LEVEL) bool {
	return loglvl > lvl
}

// Levels defines a mapping of log LEVELs to formatted level strings.
type Levels [int(ALL) + 1]string

// Default returns the default set of log levels.
func Default() Levels {
	return Levels{
		TRACE: "TRACE",
		DEBUG: "DEBUG",
		INFO:  "INFO",
		WARN:  "WARN",
		ERROR: "ERROR",
		FATAL: "FATAL",
		PANIC: "PANIC",

		// we set these just so that
		// it can be debugged when someone
		// attempts to log with ALL/UNSET
		ALL:   "{all}",
		UNSET: "{unset}",
	}
}

// Get fetches the level string for the provided value.
func (l Levels) Get(lvl LEVEL) string {
	return l[int(lvl)]
}