From ca90ebdfa8789654766c5d7969baa7afacd9ebd2 Mon Sep 17 00:00:00 2001 From: BanceDev Date: Mon, 16 Feb 2026 16:31:54 -0500 Subject: initial commit --- .../command/ftespawnbaseline/ftespawnbaseline.go | 41 ++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 packet/command/ftespawnbaseline/ftespawnbaseline.go (limited to 'packet/command/ftespawnbaseline') diff --git a/packet/command/ftespawnbaseline/ftespawnbaseline.go b/packet/command/ftespawnbaseline/ftespawnbaseline.go new file mode 100644 index 0000000..39abd1e --- /dev/null +++ b/packet/command/ftespawnbaseline/ftespawnbaseline.go @@ -0,0 +1,41 @@ +package ftespawnbaseline + +import ( + "github.com/osm/quake/common/buffer" + "github.com/osm/quake/common/context" + "github.com/osm/quake/packet/command/packetentitydelta" + "github.com/osm/quake/protocol/fte" +) + +type Command struct { + Index uint16 + Delta *packetentitydelta.Command +} + +func (cmd *Command) Bytes() []byte { + buf := buffer.New() + + buf.PutByte(fte.SVCSpawnBaseline) + buf.PutUint16(cmd.Index) + + if cmd.Delta != nil { + buf.PutBytes(cmd.Delta.Bytes()) + } + + return buf.Bytes() +} + +func Parse(ctx *context.Context, buf *buffer.Buffer) (*Command, error) { + var err error + var cmd Command + + if cmd.Index, err = buf.GetUint16(); err != nil { + return nil, err + } + + if cmd.Delta, err = packetentitydelta.Parse(ctx, buf, cmd.Index); err != nil { + return nil, err + } + + return &cmd, nil +} -- cgit v1.2.3-59-g8ed1b