Skip to content

Latest commit

 

History

History
57 lines (45 loc) · 1.46 KB

README.md

File metadata and controls

57 lines (45 loc) · 1.46 KB

roachslog

Go

This library allows cockroachdb/errors stacktrace to output as an attribute of slog.

$ go get github.com/sdual/roachslog

Usage

The following is an example of extracting stacktrace as an attribute of slog.

package main

import (
	"log/slog"
	"os"

	"github.com/cockroachdb/errors"
	"github.com/sdual/roachslog"
)

func main() {
	ops := slog.HandlerOptions{
		AddSource: true,
		Level:     slog.LevelInfo,
	}

	handler := slog.NewJSONHandler(os.Stdout, &ops)
	rsHandler := roachslog.NewReachSlogHandler(handler)
	slog.SetDefault(slog.New(rsHandler))

	err := doSomething()
	slog.Error("error occurred", roachslog.Err(err))
}

func doSomething() error {
	return errors.New("error")
}
{
	"time": "2024-09-06T12:44:15.107483+09:00",
	"level": "ERROR",
	"source": {
		"function": "main.main",
		"file": "/Users/sdual/repos/golang/sample/main.go",
		"line": 22
	},
	"msg": "error occurred",
	"error": "error",
	"stacktrace": "\nmain.doSomething\n\t/Users/sdual/repos/golang/sample/main.go:26\nmain.main\n\t/Users/sdual/repos/golang/sample/main.go:21\nruntime.main\n\t/Users/sdual/go/1.22.4/pkg/mod/golang.org/[email protected]/src/runtime/proc.go:272\nruntime.goexit\n\t/Users/sdual/go/1.22.4/pkg/mod/golang.org/[email protected]/src/runtime/asm_arm64.s:1223"
}