-
Notifications
You must be signed in to change notification settings - Fork 15
/
Packet15Layer.go
40 lines (33 loc) · 1.18 KB
/
Packet15Layer.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
package peer
import (
"fmt"
)
// Packet15Layer represents ID_DISCONNECTION_NOTIFICATION - client <-> server
type Packet15Layer struct {
Reason int32
}
func (thisStream *extendedReader) DecodePacket15Layer(reader PacketReader, layers *PacketLayers) (RakNetPacket, error) {
layer := &Packet15Layer{}
var err error
reason, err := thisStream.readUint32BE()
layer.Reason = int32(reason)
// DisconnectReceivePacketError: most parser functions -- NOT NetworkStream reading
// DisconnectReceivePacketStreamError: when reading from network streams
// DisconnectSendPacketError: from ClusterJobStep, from DataOutStep, when creating player
return layer, err
}
// Serialize implements RakNetPacket.Serialize()
func (layer *Packet15Layer) Serialize(writer PacketWriter, stream *extendedWriter) error {
return stream.writeUint32BE(uint32(layer.Reason))
}
// TypeString implements RakNetPacket.TypeString()
func (Packet15Layer) TypeString() string {
return "ID_DISCONNECTION_NOTIFICATION"
}
func (layer *Packet15Layer) String() string {
return fmt.Sprintf("ID_DISCONNECTION_NOTIFICATION: Reason %d", layer.Reason)
}
// Type implements RakNetPacket.Type()
func (Packet15Layer) Type() byte {
return 0x15
}