-
Notifications
You must be signed in to change notification settings - Fork 25
/
Copy pathlog.go
127 lines (105 loc) · 3.34 KB
/
log.go
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
// Copyright 2025 Google LLC
//
// 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.
// Package log defines SCALIBR's logger interface. By default it uses the Go logger
// but it can be replaced with user-defined loggers.
package log
import "log"
// Logger is SCALIBR's logging interface.
type Logger interface {
// Logs in different log levels, either formatted or unformatted.
Errorf(format string, args ...any)
Error(args ...any)
Warnf(format string, args ...any)
Warn(args ...any)
Infof(format string, args ...any)
Info(args ...any)
Debugf(format string, args ...any)
Debug(args ...any)
}
var logger Logger = &DefaultLogger{}
// SetLogger overwrites the default SCALIBR logger with a user specified one.
func SetLogger(l Logger) { logger = l }
// Errorf is the static formatted error logging function.
func Errorf(format string, args ...any) {
logger.Errorf(format, args...)
}
// Warnf is the static formatted warning logging function.
func Warnf(format string, args ...any) {
logger.Warnf(format, args...)
}
// Infof is the static formatted info logging function.
func Infof(format string, args ...any) {
logger.Infof(format, args...)
}
// Debugf is the static formatted debug logging function.
func Debugf(format string, args ...any) {
logger.Debugf(format, args...)
}
// Error is the static error logging function.
func Error(args ...any) {
logger.Error(args...)
}
// Warn is the static warning logging function.
func Warn(args ...any) {
logger.Warn(args...)
}
// Info is the static info logging function.
func Info(args ...any) {
logger.Info(args...)
}
// Debug is the static debug logging function.
func Debug(args ...any) {
logger.Debug(args...)
}
// DefaultLogger is the Logger implementation used by default.
// It just logs to stderr using the default Go logger.
type DefaultLogger struct {
Verbose bool // Whether debug logs should be shown.
}
// Errorf is the formatted error logging function.
func (DefaultLogger) Errorf(format string, args ...any) {
log.Printf(format, args...)
}
// Warnf is the formatted warning logging function.
func (DefaultLogger) Warnf(format string, args ...any) {
log.Printf(format, args...)
}
// Infof is the formatted info logging function.
func (DefaultLogger) Infof(format string, args ...any) {
log.Printf(format, args...)
}
// Debugf is the formatted debug logging function.
func (l *DefaultLogger) Debugf(format string, args ...any) {
if l.Verbose {
log.Printf(format, args...)
}
}
// Error is the error logging function.
func (DefaultLogger) Error(args ...any) {
log.Println(args...)
}
// Warn is the warning logging function.
func (DefaultLogger) Warn(args ...any) {
log.Println(args...)
}
// Info is the info logging function.
func (DefaultLogger) Info(args ...any) {
log.Println(args...)
}
// Debug is the debug logging function.
func (l *DefaultLogger) Debug(args ...any) {
if l.Verbose {
log.Println(args...)
}
}