package main import ( "context" "fmt" "log/slog" "os" "runtime/debug" "git.netflux.io/rob/octoplex/internal/client" "git.netflux.io/rob/octoplex/internal/domain" "golang.design/x/clipboard" ) var ( // version is the version of the application. version string // commit is the commit hash of the application. commit string // date is the date of the build. date string ) func main() { if err := run(); err != nil { os.Stderr.WriteString("Error: " + err.Error() + "\n") os.Exit(1) } } func run() error { ctx, cancel := context.WithCancel(context.Background()) defer cancel() // TODO: logger from config fptr, err := os.OpenFile("octoplex.log", os.O_RDWR|os.O_CREATE|os.O_APPEND, 0666) if err != nil { return fmt.Errorf("open log file: %w", err) } logger := slog.New(slog.NewTextHandler(fptr, nil)) var clipboardAvailable bool if err = clipboard.Init(); err != nil { logger.Warn("Clipboard not available", "err", err) } else { clipboardAvailable = true } buildInfo, ok := debug.ReadBuildInfo() if !ok { return fmt.Errorf("read build info: %w", err) } app := client.New(client.NewParams{ ClipboardAvailable: clipboardAvailable, BuildInfo: domain.BuildInfo{ GoVersion: buildInfo.GoVersion, Version: version, Commit: commit, Date: date, }, Logger: logger, }) if err := app.Run(ctx); err != nil { return fmt.Errorf("run app: %w", err) } return nil }