Improve logging

This commit is contained in:
Torjus Håkestad 2024-03-09 22:57:46 +01:00
parent d82d2a7f8e
commit a1fa070078

41
main.go
View File

@ -1,14 +1,27 @@
package main package main
import ( import (
"fmt" "context"
"errors"
"log/slog"
"os" "os"
"os/signal"
"github.com/godbus/dbus/v5" "github.com/godbus/dbus/v5"
"github.com/holoplot/go-evdev" "github.com/holoplot/go-evdev"
) )
func main() { func main() {
// Setup logger
h := slog.NewJSONHandler(os.Stdout, &slog.HandlerOptions{Level: slog.LevelInfo})
logger := slog.New(h)
slog.SetDefault(logger)
// Setup signal handler
ctx, stop := signal.NotifyContext(context.Background(), os.Interrupt)
defer stop()
// Connect to dbus
conn, err := dbus.ConnectSessionBus() conn, err := dbus.ConnectSessionBus()
if err != nil { if err != nil {
panic(err) panic(err)
@ -22,19 +35,37 @@ func main() {
if err != nil { if err != nil {
panic(err) panic(err)
} }
defer input.Close()
input.NonBlock()
for { var done bool
// Listen for context cancellation
go func() {
<-ctx.Done()
done = true
input.Close()
}()
// Start listening for PTT key
for !done {
ev, err := input.ReadOne() ev, err := input.ReadOne()
if err != nil { if err != nil {
panic(err) if errors.Is(err, os.ErrClosed) {
continue
}
slog.Error("Error reading fron input device", "error", err)
os.Exit(1)
} }
if ev.Code == evdev.KEY_F24 && ev.Value == 1 { if ev.Code == evdev.KEY_F24 && ev.Value == 1 {
fmt.Printf("PTT ON!\n") slog.Info("PTT ON")
obj.Go("net.sourceforge.mumble.Mumble.startTalking", 0, nil) obj.Go("net.sourceforge.mumble.Mumble.startTalking", 0, nil)
} }
if ev.Code == evdev.KEY_F24 && ev.Value == 0 { if ev.Code == evdev.KEY_F24 && ev.Value == 0 {
fmt.Printf("PTT OFF!\n") slog.Info("PTT OFF")
obj.Go("net.sourceforge.mumble.Mumble.stopTalking", 0, nil) obj.Go("net.sourceforge.mumble.Mumble.stopTalking", 0, nil)
} }
} }
obj.Go("net.sourceforge.mumble.Mumble.stopTalking", 0, nil)
slog.Info("Exiting")
} }