mirror of
https://github.com/42wim/matterbridge.git
synced 2025-01-22 06:49:02 -08:00
52 lines
1.2 KiB
Go
52 lines
1.2 KiB
Go
|
package socketmode
|
||
|
|
||
|
import "fmt"
|
||
|
|
||
|
// TODO merge logger, ilogger, and internalLogger with the top-level package's equivalents
|
||
|
|
||
|
// logger is a logger interface compatible with both stdlib and some
|
||
|
// 3rd party loggers.
|
||
|
type logger interface {
|
||
|
Output(int, string) error
|
||
|
}
|
||
|
|
||
|
// ilogger represents the internal logging api we use.
|
||
|
type ilogger interface {
|
||
|
logger
|
||
|
Print(...interface{})
|
||
|
Printf(string, ...interface{})
|
||
|
Println(...interface{})
|
||
|
}
|
||
|
|
||
|
// internalLog implements the additional methods used by our internal logging.
|
||
|
type internalLog struct {
|
||
|
logger
|
||
|
}
|
||
|
|
||
|
// Println replicates the behaviour of the standard logger.
|
||
|
func (t internalLog) Println(v ...interface{}) {
|
||
|
t.Output(2, fmt.Sprintln(v...))
|
||
|
}
|
||
|
|
||
|
// Printf replicates the behaviour of the standard logger.
|
||
|
func (t internalLog) Printf(format string, v ...interface{}) {
|
||
|
t.Output(2, fmt.Sprintf(format, v...))
|
||
|
}
|
||
|
|
||
|
// Print replicates the behaviour of the standard logger.
|
||
|
func (t internalLog) Print(v ...interface{}) {
|
||
|
t.Output(2, fmt.Sprint(v...))
|
||
|
}
|
||
|
|
||
|
func (smc *Client) Debugf(format string, v ...interface{}) {
|
||
|
if smc.debug {
|
||
|
smc.log.Output(2, fmt.Sprintf(format, v...))
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func (smc *Client) Debugln(v ...interface{}) {
|
||
|
if smc.debug {
|
||
|
smc.log.Output(2, fmt.Sprintln(v...))
|
||
|
}
|
||
|
}
|