diff options
| author | 2026-02-16 16:31:54 -0500 | |
|---|---|---|
| committer | 2026-02-16 16:31:54 -0500 | |
| commit | ca90ebdfa8789654766c5d7969baa7afacd9ebd2 (patch) | |
| tree | 9693e0c7a5af6713f4c5e39372dcf22d05844ec3 /packet/command/ftevoicechats/ftevoicechats.go | |
Diffstat (limited to '')
| -rw-r--r-- | packet/command/ftevoicechats/ftevoicechats.go | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/packet/command/ftevoicechats/ftevoicechats.go b/packet/command/ftevoicechats/ftevoicechats.go new file mode 100644 index 0000000..be4109d --- /dev/null +++ b/packet/command/ftevoicechats/ftevoicechats.go @@ -0,0 +1,55 @@ +package ftevoicechats + +import ( + "github.com/osm/quake/common/buffer" + "github.com/osm/quake/common/context" + "github.com/osm/quake/protocol/fte" +) + +type Command struct { + Sender byte + Gen byte + Seq byte + Size uint16 + Data []byte +} + +func (cmd *Command) Bytes() []byte { + buf := buffer.New() + + buf.PutByte(fte.SVCVoiceChat) + buf.PutByte(cmd.Sender) + buf.PutByte(cmd.Gen) + buf.PutByte(cmd.Seq) + buf.PutUint16(cmd.Size) + buf.PutBytes(cmd.Data) + + return buf.Bytes() +} + +func Parse(ctx *context.Context, buf *buffer.Buffer) (*Command, error) { + var err error + var cmd Command + + if cmd.Sender, err = buf.ReadByte(); err != nil { + return nil, err + } + + if cmd.Gen, err = buf.ReadByte(); err != nil { + return nil, err + } + + if cmd.Seq, err = buf.ReadByte(); err != nil { + return nil, err + } + + if cmd.Size, err = buf.GetUint16(); err != nil { + return nil, err + } + + if cmd.Data, err = buf.GetBytes(int(cmd.Size)); err != nil { + return nil, err + } + + return &cmd, nil +} |
