diff options
| author | Arda Serdar Pektezol <1669855+pektezol@users.noreply.github.com> | 2022-11-07 18:42:28 +0300 |
|---|---|---|
| committer | Arda Serdar Pektezol <1669855+pektezol@users.noreply.github.com> | 2023-09-16 21:39:38 +0300 |
| commit | 8352bfc1d8deedd4d6a0a5b0698fe1f8b9a06e88 (patch) | |
| tree | 69fd0825f69ff70fe0c8ae597cfe20a91af2d961 /packets/classes/stringtable.go | |
| parent | starting stringtable (diff) | |
| download | sdp.go-8352bfc1d8deedd4d6a0a5b0698fe1f8b9a06e88.tar.gz sdp.go-8352bfc1d8deedd4d6a0a5b0698fe1f8b9a06e88.tar.bz2 sdp.go-8352bfc1d8deedd4d6a0a5b0698fe1f8b9a06e88.zip | |
stringtable done, can't see data properly
Diffstat (limited to 'packets/classes/stringtable.go')
| -rw-r--r-- | packets/classes/stringtable.go | 36 |
1 files changed, 35 insertions, 1 deletions
diff --git a/packets/classes/stringtable.go b/packets/classes/stringtable.go index df8e840..64e8496 100644 --- a/packets/classes/stringtable.go +++ b/packets/classes/stringtable.go | |||
| @@ -1,5 +1,39 @@ | |||
| 1 | package classes | 1 | package classes |
| 2 | 2 | ||
| 3 | func ParseStringTable() { | 3 | import ( |
| 4 | "bytes" | ||
| 4 | 5 | ||
| 6 | "github.com/pektezol/bitreader" | ||
| 7 | ) | ||
| 8 | |||
| 9 | func ParseStringTable(data []byte) []StringTable { | ||
| 10 | reader := bitreader.Reader(bytes.NewReader(data), true) | ||
| 11 | var stringTables []StringTable | ||
| 12 | numOfTables := reader.TryReadInt8() | ||
| 13 | for i := 0; i < int(numOfTables); i++ { | ||
| 14 | var stringTable StringTable | ||
| 15 | stringTable.TableName = reader.TryReadString() | ||
| 16 | stringTable.NumOfEntries = int16(reader.TryReadInt16()) | ||
| 17 | stringTable.EntryName = reader.TryReadString() | ||
| 18 | if reader.TryReadBool() { | ||
| 19 | stringTable.EntrySize = int16(reader.TryReadInt16()) | ||
| 20 | } | ||
| 21 | if reader.TryReadBool() { | ||
| 22 | stringTable.EntryData = reader.TryReadBytesToSlice(int(stringTable.EntrySize)) | ||
| 23 | } | ||
| 24 | if reader.TryReadBool() { | ||
| 25 | stringTable.NumOfClientEntries = int16(reader.TryReadInt16()) | ||
| 26 | } | ||
| 27 | if reader.TryReadBool() { | ||
| 28 | stringTable.ClientEntryName = reader.TryReadString() | ||
| 29 | } | ||
| 30 | if reader.TryReadBool() { | ||
| 31 | stringTable.ClientEntrySize = int16(reader.TryReadInt16()) | ||
| 32 | } | ||
| 33 | if reader.TryReadBool() { | ||
| 34 | stringTable.ClientEntryData = reader.TryReadBytesToSlice(int(stringTable.ClientEntrySize)) | ||
| 35 | } | ||
| 36 | stringTables = append(stringTables, stringTable) | ||
| 37 | } | ||
| 38 | return stringTables | ||
| 5 | } | 39 | } |