-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
105 lines (89 loc) · 2 KB
/
main.go
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
package main
import (
"encoding/json"
"log"
"os"
"time"
"github.com/BurntSushi/xgb"
"github.com/BurntSushi/xgb/randr"
"github.com/BurntSushi/xgb/xproto"
"github.com/urfave/cli/v2"
)
type Batch struct {
Events []xgb.Event
}
func main() {
log := log.New(os.Stderr, "", log.LstdFlags)
app := &cli.App{
Name: "randr-notify",
Flags: []cli.Flag{
&cli.DurationFlag{
Name: "accumulation-timeout",
Aliases: []string{"a"},
Usage: "The maximum duration to wait to add another event to the batch.",
Value: 1 * time.Second,
},
},
Action: func(c *cli.Context) error {
x, err := xgb.NewConn()
if err != nil {
return cli.Exit(err.Error(), 100)
}
if err := randr.Init(x); err != nil {
log.Fatal(err.Error())
return cli.Exit(err.Error(), 101)
}
// Get the root window on the default screen.
root := xproto.Setup(x).DefaultScreen(x).Root
// Tell RandR to send us events.
if err := randr.SelectInputChecked(x, root,
randr.NotifyMaskScreenChange|
randr.NotifyMaskCrtcChange|
randr.NotifyMaskOutputChange|
randr.NotifyMaskOutputProperty).Check(); err != nil {
return cli.Exit(err.Error(), 102)
}
encoder := json.NewEncoder(os.Stdout)
events := make(chan xgb.Event)
// Write x events to channel
go func() {
for {
e, err := x.WaitForEvent()
if err != nil {
log.Fatal(err.Error())
return
}
events <- e
}
}()
// Monitor x events channel
for e := range events {
batch := Batch{
Events: []xgb.Event{
e,
},
}
// accumulate events before write them as json output
loop:
for {
select {
case e, ok := <-events:
if !ok {
break
}
batch.Events = append(batch.Events, e)
case <-time.After(c.Duration("accumulation-timeout")):
break loop
}
}
if err := encoder.Encode(batch); err != nil {
log.Fatal(err)
}
}
return nil
},
}
if err := app.Run(os.Args); err != nil {
log.Fatal(err)
}
}