Horizon Official Technical Documentation
Horizon::Zone::ZC_ACK_REQ_CHANGE_MEMBERS Class Reference

Main object for the aegis packet: ZC_ACK_REQ_CHANGE_MEMBERS. More...

#include <TransmittedPackets.hpp>

+ Inheritance diagram for Horizon::Zone::ZC_ACK_REQ_CHANGE_MEMBERS:
+ Collaboration diagram for Horizon::Zone::ZC_ACK_REQ_CHANGE_MEMBERS:

Public Member Functions

 ZC_ACK_REQ_CHANGE_MEMBERS (std::shared_ptr< ZoneSession > s)
 
virtual ~ZC_ACK_REQ_CHANGE_MEMBERS ()
 
void deliver (std::vector< s_zcack_reqchange_members > members)
 ZC_ACK_REQ_CHANGE_MEMBERS. More...
 
ByteBufferserialize ()
 
- Public Member Functions inherited from Horizon::Base::NetworkPacket< ZoneSession >
 NetworkPacket (uint16_t packet_id, std::shared_ptr< ZoneSession > s)
 
virtual ~NetworkPacket ()
 
void set_packet_id (uint16_t id)
 
uint16_t get_packet_id ()
 
ByteBufferbuf ()
 
std::shared_ptr< ZoneSession > get_session ()
 Retrieves the session from this handler instance. More...
 
virtual void handle (ByteBuffer &&buf)
 
virtual void deserialize (ByteBuffer &buf)
 
void transmit ()
 Send an Asynchronous packet by queueing a buffer of a particular size to the connected session. More...
 
void transmit (std::size_t size)
 Send an Asynchronous packet by queueing a buffer of a particular size to the connected session. More...
 

Public Attributes

int16_t _packet_length { 0 }
 
std::vector< s_zcack_reqchange_members_members
 

Additional Inherited Members

- Protected Attributes inherited from Horizon::Base::NetworkPacket< ZoneSession >
ByteBuffer _buffer
 Buffer storage facility for the packet stream. More...
 
uint16_t _packet_id
 ID of the network packet. More...
 

Detailed Description

Main object for the aegis packet: ZC_ACK_REQ_CHANGE_MEMBERS.

Constructor & Destructor Documentation

◆ ZC_ACK_REQ_CHANGE_MEMBERS()

Horizon::Zone::ZC_ACK_REQ_CHANGE_MEMBERS::ZC_ACK_REQ_CHANGE_MEMBERS ( std::shared_ptr< ZoneSession s)
inline
17903 : NetworkPacket<ZoneSession>(ID_ZC_ACK_REQ_CHANGE_MEMBERS, s)
17904 {}
@ ID_ZC_ACK_REQ_CHANGE_MEMBERS
Definition: TransmittedPackets.hpp:17876

◆ ~ZC_ACK_REQ_CHANGE_MEMBERS()

virtual Horizon::Zone::ZC_ACK_REQ_CHANGE_MEMBERS::~ZC_ACK_REQ_CHANGE_MEMBERS ( )
inlinevirtual
17905{}

Member Function Documentation

◆ deliver()

void ZC_ACK_REQ_CHANGE_MEMBERS::deliver ( std::vector< s_zcack_reqchange_members members)

ZC_ACK_REQ_CHANGE_MEMBERS.

486{
487 _packet_length = 4 + sizeof(s_zcack_reqchange_members) * members.size();
488 _members = members;
489
490 serialize();
491 transmit();
492}
void transmit()
Send an Asynchronous packet by queueing a buffer of a particular size to the connected session.
Definition: NetworkPacket.hpp:94
int16_t _packet_length
Definition: TransmittedPackets.hpp:17911
ByteBuffer & serialize()
Definition: TransmittedPackets.cpp:494
std::vector< s_zcack_reqchange_members > _members
Definition: TransmittedPackets.hpp:17912
Definition: ClientDefinitions.hpp:513

References _members, _packet_length, serialize(), and Horizon::Base::NetworkPacket< ZoneSession >::transmit().

+ Here is the call graph for this function:

◆ serialize()

ByteBuffer & ZC_ACK_REQ_CHANGE_MEMBERS::serialize ( )
495{
496 buf() << _packet_id;
497 buf() << _packet_length;
498 for (auto m : _members) {
499 buf() << m.account_id;
500 buf() << m.char_id;
501 buf() << m.position_id;
502 }
503 return buf();
504}
uint16_t _packet_id
ID of the network packet.
Definition: NetworkPacket.hpp:87
ByteBuffer & buf()
Definition: NetworkPacket.hpp:59

References _members, Horizon::Base::NetworkPacket< ZoneSession >::_packet_id, _packet_length, and Horizon::Base::NetworkPacket< ZoneSession >::buf().

Referenced by deliver().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

Member Data Documentation

◆ _members

std::vector<s_zcack_reqchange_members> Horizon::Zone::ZC_ACK_REQ_CHANGE_MEMBERS::_members

Referenced by deliver(), and serialize().

◆ _packet_length

int16_t Horizon::Zone::ZC_ACK_REQ_CHANGE_MEMBERS::_packet_length { 0 }

Referenced by deliver(), and serialize().


The documentation for this class was generated from the following files: