-
Notifications
You must be signed in to change notification settings - Fork 80
/
mtk.go
46 lines (43 loc) · 1.6 KB
/
mtk.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
package nmea
const (
// TypeMTK type for PMTK sentences
// Deprecated: use PMTK001 instead. PMTK protocol contains actually many commands. This struct is for MTK 001 ACK command.
TypeMTK = "MTK001"
)
// MTK is sentence for NMEA embedded command packet protocol, command type 001 - ACK.
// https://www.rhydolabz.com/documents/25/PMTK_A11.pdf
// https://www.sparkfun.com/datasheets/GPS/Modules/PMTK_Protocol.pdf
//
// The maximum length of each packet is restricted to 255 bytes which is longer than NMEA0183 82 bytes.
//
// Format: $PMTKxxx,c-c*hh<CR><LF>
// Example: $PMTK000*32<CR><LF>
//
// $PMTK001,101,0*33<CR><LF>
//
// Deprecated: use PMTK001 instead. PMTK protocol contains actually many commands. This struct is for MTK 001 ACK command.
type MTK struct {
BaseSentence
Cmd, // Three bytes character string. From "000" to "999". An identifier used to tell the decoder how to decode the packet
// Flag is flag field in PMTK001 packet.
// Note: this field on only relevant for `PMTK001,Cmd,Flag` sentence.
// Actual MTK protocol has variable amount of fields (whole sentence can be up to 255 bytes)
//
// Actual docs say:
// DataField: The DataField has variable length depending on the packet type. A comma symbol ‘,’ must be inserted
// ahead each data filed to help the decoder process the DataField.
Flag int64
}
// newMTK constructor
// Deprecated: use newPMTK001 instead
func newMTK(s BaseSentence) (Sentence, error) {
p := NewParser(s)
p.AssertType(TypeMTK)
cmd := p.Int64(0, "command")
flag := p.Int64(1, "flag")
return MTK{
BaseSentence: s,
Cmd: cmd,
Flag: flag,
}, p.Err()
}