-
Notifications
You must be signed in to change notification settings - Fork 13
/
interval-report.gen.go
94 lines (70 loc) · 1.75 KB
/
interval-report.gen.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
// THIS FILE IS AUTO-GENERATED BY ZWGEN
// DO NOT MODIFY
package wakeupv2
import (
"encoding/binary"
"encoding/gob"
"errors"
"github.com/gozwave/gozw/cc"
)
const CommandIntervalReport cc.CommandID = 0x06
func init() {
gob.Register(IntervalReport{})
cc.Register(cc.CommandIdentifier{
CommandClass: cc.CommandClassID(0x84),
Command: cc.CommandID(0x06),
Version: 2,
}, NewIntervalReport)
}
func NewIntervalReport() cc.Command {
return &IntervalReport{}
}
// <no value>
type IntervalReport struct {
Seconds uint32
Nodeid byte
}
func (cmd IntervalReport) CommandClassID() cc.CommandClassID {
return 0x84
}
func (cmd IntervalReport) CommandID() cc.CommandID {
return CommandIntervalReport
}
func (cmd IntervalReport) CommandIDString() string {
return "WAKE_UP_INTERVAL_REPORT"
}
func (cmd *IntervalReport) UnmarshalBinary(data []byte) error {
// According to the docs, we must copy data if we wish to retain it after returning
payload := make([]byte, len(data))
copy(payload, data)
if len(payload) < 2 {
return errors.New("Payload length underflow")
}
i := 2
if len(payload) <= i {
return errors.New("slice index out of bounds")
}
cmd.Seconds = binary.BigEndian.Uint32(payload[i : i+3])
i += 3
if len(payload) <= i {
return errors.New("slice index out of bounds")
}
cmd.Nodeid = payload[i]
i++
return nil
}
func (cmd *IntervalReport) MarshalBinary() (payload []byte, err error) {
payload = make([]byte, 2)
payload[0] = byte(cmd.CommandClassID())
payload[1] = byte(cmd.CommandID())
{
buf := make([]byte, 4)
binary.BigEndian.PutUint32(buf, cmd.Seconds)
if buf[0] != 0 {
return nil, errors.New("BIT_24 value overflow")
}
payload = append(payload, buf[1:4]...)
}
payload = append(payload, cmd.Nodeid)
return
}