buildr/internal/logging/setup.go

46 lines
742 B
Go
Raw Normal View History

package logging
import (
"flag"
"log/slog"
"os"
)
func NewConfig() Config {
return Config{
LogLevel: new(slog.LevelVar),
}
}
type Config struct {
LogLevel *slog.LevelVar
AddSource bool
}
func (c *Config) Flags() *flag.FlagSet {
flagSet := flag.NewFlagSet("logging", flag.PanicOnError)
flagSet.TextVar(
c.LogLevel,
"log.level",
c.LogLevel,
"set log level",
)
flagSet.BoolVar(
&c.AddSource,
"log.add-source",
false,
"Enable to get detailed information where the log was produced",
)
return flagSet
}
func (c *Config) Logger() *slog.Logger {
slogOptions := slog.HandlerOptions{
AddSource: c.AddSource,
Level: c.LogLevel.Level(),
}
2023-05-24 20:10:01 +00:00
return slog.New(slog.NewTextHandler(os.Stderr, &slogOptions))
}