Improve logging
This commit is contained in:
parent
d82d2a7f8e
commit
a1fa070078
41
main.go
41
main.go
@ -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")
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user