buildr/main.go

36 lines
640 B
Go

package main
import (
"context"
"errors"
"os"
"os/signal"
"golang.org/x/exp/slog"
"code.icb4dc0.de/buildr/buildr/internal/cmd"
"code.icb4dc0.de/buildr/buildr/internal/errs"
)
func main() {
slogOptions := slog.HandlerOptions{
AddSource: true,
Level: slog.LevelInfo,
}
slog.SetDefault(slog.New(slogOptions.NewTextHandler(os.Stderr)))
ctx, cancel := signal.NotifyContext(context.Background(), os.Interrupt, os.Kill)
defer cancel()
app := cmd.NewApp()
if err := app.Run(ctx); err != nil {
if !errors.Is(err, errs.ErrAlreadyLogged) {
slog.Error("Error occurred", slog.Any("error", err))
}
os.Exit(1)
}
}