aboutsummaryrefslogtreecommitdiff
path: root/messages/messages.go
blob: b40684bd85985f3a452b323b4110476b8d0ff034 (plain) (blame)
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
package messages

import (
	"fmt"
	"os"

	"github.com/pektezol/bitreader"
	"github.com/pektezol/demoparser/classes"
	"github.com/pektezol/demoparser/classes/netsvc"
	"github.com/pektezol/demoparser/utils"
)

func ParseMessage(file *os.File) (statusCode int) {
	reader := bitreader.Reader(file, true)
	messageType := reader.TryReadInt8()
	messageTick := reader.TryReadInt32()
	messageSlot := reader.TryReadInt8()
	//fmt.Println(messageType, messageTick, messageSlot)
	switch messageType {
	case 0x01: // SignOn
		var packet Packet
		packet.PacketInfo = classes.ParseCmdInfo(file, 2)
		packet.InSequence = int32(reader.TryReadInt32())
		packet.OutSequence = int32(reader.TryReadInt32())
		packet.Size = int32(reader.TryReadInt32())
		data := utils.ReadByteFromFile(file, packet.Size)
		//fmt.Println(data)
		netsvc.ParseNetSvcMessage(data)
		//reader.SkipBytes(int(packet.Size)) // TODO: NET/SVC Message Parsing
		fmt.Printf("[%d] (%d) SignOn: %v\n", messageTick, messageSlot, packet)
		return 1
	case 0x02: // Packet
		var packet Packet
		packet.PacketInfo = classes.ParseCmdInfo(file, 2)
		packet.InSequence = int32(reader.TryReadInt32())
		packet.OutSequence = int32(reader.TryReadInt32())
		packet.Size = int32(reader.TryReadInt32())
		reader.SkipBytes(int(packet.Size)) // TODO: NET/SVC Message Parsing
		//fmt.Printf("[%d] Packet: %v\n", messageTick, packet)
		return 2
	case 0x03: // SyncTick
		return 3
	case 0x04: // ConsoleCmd
		var consolecmd ConsoleCmd
		consolecmd.Size = int32(reader.TryReadInt32())
		consolecmd.Data = string(utils.ReadByteFromFile(file, consolecmd.Size))
		//fmt.Printf("[%d] ConsoleCmd: %s\n", messageTick, consolecmd.Data)
		return 4
	case 0x05: // UserCmd
		var usercmd UserCmd
		usercmd.Cmd = int32(reader.TryReadInt32())
		usercmd.Size = int32(reader.TryReadInt32())
		usercmd.Data = classes.ParseUserCmdInfo(file, int(usercmd.Size))
		//fmt.Printf("[%d] UserCmd: %v\n", messageTick, usercmd.Data)
		return 5
	case 0x06: // DataTables
		var datatables DataTables
		datatables.Size = int32(reader.TryReadInt32())
		reader.SkipBytes(int(datatables.Size)) // TODO: DataTables Data
		return 6
	case 0x07: // Stop
		fmt.Printf("[%d] Stop\n", messageTick)
		return 7
	case 0x08: // CustomData
		var customdata CustomData
		customdata.Unknown = int32(reader.TryReadInt32())
		customdata.Size = int32(reader.TryReadInt32())
		reader.SkipBytes(int(customdata.Size)) // TODO: CustomData Data
		return 8
	case 0x09: // StringTables
		var stringtables StringTables
		stringtables.Size = int32(reader.TryReadInt32())
		reader.SkipBytes(int(stringtables.Size)) // TODO: StringTables Data
		return 9
	default:
		return 0
	}
}