Skip to content

Commit

Permalink
A few slog tweaks
Browse files Browse the repository at this point in the history
  • Loading branch information
prymitive committed Oct 19, 2023
1 parent a659800 commit 2aa81cc
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 24 deletions.
39 changes: 18 additions & 21 deletions internal/log/handler.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,20 +12,17 @@ import (
)

const (
reset = "\033[0m"
dim = "\033[2m"
normal = "\u001B[22m"

fgHiRed = "\033[91m"
fgHiYellow = "\033[93m"
fgHiBlue = "\033[94m"
fgHiMagenta = "\033[95m"
fgHiCyan = "\033[96m"
fgHiWhite = "\033[97m"
dim = 2
fgHiRed = 91
fgHiYellow = 93
fgHiBlue = 94
fgHiMagenta = 95
fgHiCyan = 96
fgHiWhite = 97
)

type handler struct {
mtx *sync.Mutex
mtx sync.Mutex
dst io.Writer
level slog.Level
noColor bool
Expand All @@ -35,12 +32,12 @@ type handler struct {

func newHandler(dst io.Writer, level slog.Level, noColor bool) *handler {
h := handler{
mtx: &sync.Mutex{},
mtx: sync.Mutex{},
dst: dst,
level: level,
noColor: noColor,
escaper: strings.NewReplacer(`"`, `\"`),
}
h.escaper = strings.NewReplacer(`"`, `\"`)
return &h
}

Expand All @@ -49,9 +46,9 @@ func (h *handler) Enabled(_ context.Context, level slog.Level) bool {
}

func (h *handler) Handle(_ context.Context, record slog.Record) error {
buf := bytes.NewBuffer(make([]byte, 0, 256))
buf := bytes.NewBuffer(make([]byte, 0, 128))

lc := ""
var lc int
switch record.Level {
case slog.LevelInfo:
lc = fgHiWhite
Expand All @@ -64,16 +61,16 @@ func (h *handler) Handle(_ context.Context, record slog.Record) error {
}
h.printKey(buf, "level")
h.printVal(buf, record.Level.String(), lc)
_, _ = buf.WriteString(" ")
_, _ = buf.WriteRune(' ')
h.printKey(buf, "msg")
h.printVal(buf, record.Message, fgHiWhite)

record.Attrs(func(attr slog.Attr) bool {
_, _ = buf.WriteString(" ")
_, _ = buf.WriteRune(' ')
h.appendAttr(buf, attr)
return true
})
buf.WriteString("\n")
_, _ = buf.WriteRune('\n')

h.mtx.Lock()
defer h.mtx.Unlock()
Expand All @@ -97,18 +94,18 @@ func (h *handler) printKey(buf *bytes.Buffer, s string) {
_, _ = buf.WriteString(h.maybeWriteColor(s+"=", dim))
}

func (h *handler) printVal(buf *bytes.Buffer, s, color string) {
func (h *handler) printVal(buf *bytes.Buffer, s string, color int) {
if !strings.HasPrefix(s, "[") && !strings.HasPrefix(s, "{") && strings.Contains(s, " ") {
s = "\"" + h.escaper.Replace(s) + "\""
}
_, _ = buf.WriteString(h.maybeWriteColor(s, color))
}

func (h *handler) maybeWriteColor(s, color string) string {
func (h *handler) maybeWriteColor(s string, color int) string {
if h.noColor {
return s
}
return fmt.Sprintf("%s%s%s", color, s, reset)
return fmt.Sprintf("\033[%dm%s\033[0m", color, s)
}

func (h *handler) appendAttr(buf *bytes.Buffer, attr slog.Attr) {
Expand Down
6 changes: 3 additions & 3 deletions internal/log/log.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,13 @@ import (

var Level = &slog.LevelVar{}

func Setup(level slog.Leveler, noColor bool) {
func Setup(level slog.Level, noColor bool) {
Level.Set(level.Level())
logger := slog.New(newHandler(os.Stderr, Level.Level(), noColor))
slog.SetDefault(logger)
}

func ParseLevel(s string) (slog.Leveler, error) {
func ParseLevel(s string) (slog.Level, error) {
switch strings.ToLower(s) {
case "error":
return slog.LevelError, nil
Expand All @@ -26,6 +26,6 @@ func ParseLevel(s string) (slog.Leveler, error) {
case "debug":
return slog.LevelDebug, nil
default:
return nil, fmt.Errorf("%q is not a valid log level", s)
return slog.LevelInfo, fmt.Errorf("%q is not a valid log level", s)
}
}

0 comments on commit 2aa81cc

Please sign in to comment.