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
|
package packets
import (
"github.com/pektezol/bitreader"
"github.com/pektezol/sdp.go/pkg/classes"
"github.com/pektezol/sdp.go/pkg/types"
)
func ParseMessage(reader *bitreader.Reader, demo *types.Demo) types.Message {
message := types.Message{
PacketType: types.MessageType(reader.TryReadUInt8()),
TickNumber: reader.TryReadSInt32(),
SlotNumber: reader.TryReadUInt8(),
}
demo.Writer.AppendLine("[%d] %s (%d):", message.TickNumber, message.PacketType.String(), message.PacketType)
switch message.PacketType {
case types.SignOn:
signOn := classes.SignOn{}
signOn.ParseSignOn(reader, demo)
message.Data = signOn
case types.Packet:
packet := classes.Packet{}
packet.ParsePacket(reader, demo)
message.Data = packet
case types.SyncTick:
syncTick := classes.SyncTick{}
syncTick.ParseSyncTick()
message.Data = syncTick
case types.ConsoleCmd:
consoleCmd := classes.ConsoleCmd{}
consoleCmd.ParseConsoleCmd(reader, demo)
message.Data = consoleCmd
case types.UserCmd:
userCmd := classes.UserCmd{}
userCmd.ParseUserCmd(reader, demo)
message.Data = userCmd
case types.DataTables:
dataTables := classes.DataTables{}
dataTables.ParseDataTables(reader, demo)
message.Data = dataTables
case types.Stop:
stop := classes.Stop{}
stop.ParseStop(reader, demo)
message.Data = stop
case types.CustomData: // TODO: not sar data
customData := classes.CustomData{}
customData.ParseCustomData(reader, message.TickNumber, uint8(message.PacketType), demo)
message.Data = customData
case types.StringTables: // TODO: parsing string table data
stringTables := classes.StringTables{}
stringTables.ParseStringTables(reader, demo)
message.Data = stringTables
default:
panic("invalid packet type")
}
return message
}
|