-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.go
More file actions
52 lines (44 loc) · 1.18 KB
/
main.go
File metadata and controls
52 lines (44 loc) · 1.18 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
package main
import (
"context"
"embed"
"log/slog"
"os"
"github.com/prxssh/rabbit/internal/ui"
"github.com/prxssh/rabbit/pkg/logging"
"github.com/wailsapp/wails/v2"
"github.com/wailsapp/wails/v2/pkg/options"
"github.com/wailsapp/wails/v2/pkg/options/assetserver"
)
//go:embed all:frontend/dist
var assets embed.FS
func main() {
setupLogger()
client, err := ui.NewClient()
if err != nil {
slog.Error("failed to initialize rabbit client", "error", err.Error())
os.Exit(1)
}
err = wails.Run(&options.App{
Title: "Rabbit - BitTorrent Client & Search Engine",
Width: 1024,
Height: 768,
Fullscreen: true,
AssetServer: &assetserver.Options{Assets: assets},
OnStartup: func(ctx context.Context) { client.Startup(ctx) },
BackgroundColour: &options.RGBA{R: 27, G: 38, B: 54, A: 1},
Bind: []any{client},
})
if err != nil {
slog.Error("failed to start wails", "error", err.Error())
os.Exit(1)
}
}
func setupLogger() {
opts := logging.DefaultOptions()
opts.SlogOpts.Level = slog.LevelDebug
opts.SlogOpts.AddSource = true
h := logging.NewPrettyHandler(os.Stdout, &opts)
l := slog.New(h)
slog.SetDefault(l)
}