mirror of
https://github.com/godotengine/godot.git
synced 2025-01-24 03:24:32 -05:00
Merge pull request #25004 from Faless/enet/proto_optimize
Save 4 bytes in ENet multiplayer protocol.
This commit is contained in:
commit
a033c686f9
1 changed files with 7 additions and 9 deletions
|
@ -346,11 +346,10 @@ void NetworkedMultiplayerENet::poll() {
|
|||
|
||||
uint32_t *id = (uint32_t *)event.peer->data;
|
||||
|
||||
ERR_CONTINUE(event.packet->dataLength < 12)
|
||||
ERR_CONTINUE(event.packet->dataLength < 8)
|
||||
|
||||
uint32_t source = decode_uint32(&event.packet->data[0]);
|
||||
int target = decode_uint32(&event.packet->data[4]);
|
||||
uint32_t flags = decode_uint32(&event.packet->data[8]);
|
||||
|
||||
packet.from = source;
|
||||
packet.channel = event.channelID;
|
||||
|
@ -371,7 +370,7 @@ void NetworkedMultiplayerENet::poll() {
|
|||
if (uint32_t(E->key()) == source) // Do not resend to self
|
||||
continue;
|
||||
|
||||
ENetPacket *packet2 = enet_packet_create(packet.packet->data, packet.packet->dataLength, flags);
|
||||
ENetPacket *packet2 = enet_packet_create(packet.packet->data, packet.packet->dataLength, packet.packet->flags);
|
||||
|
||||
enet_peer_send(E->get(), event.channelID, packet2);
|
||||
}
|
||||
|
@ -385,7 +384,7 @@ void NetworkedMultiplayerENet::poll() {
|
|||
if (uint32_t(E->key()) == source || E->key() == -target) // Do not resend to self, also do not send to excluded
|
||||
continue;
|
||||
|
||||
ENetPacket *packet2 = enet_packet_create(packet.packet->data, packet.packet->dataLength, flags);
|
||||
ENetPacket *packet2 = enet_packet_create(packet.packet->data, packet.packet->dataLength, packet.packet->flags);
|
||||
|
||||
enet_peer_send(E->get(), event.channelID, packet2);
|
||||
}
|
||||
|
@ -503,8 +502,8 @@ Error NetworkedMultiplayerENet::get_packet(const uint8_t **r_buffer, int &r_buff
|
|||
current_packet = incoming_packets.front()->get();
|
||||
incoming_packets.pop_front();
|
||||
|
||||
*r_buffer = (const uint8_t *)(¤t_packet.packet->data[12]);
|
||||
r_buffer_size = current_packet.packet->dataLength - 12;
|
||||
*r_buffer = (const uint8_t *)(¤t_packet.packet->data[8]);
|
||||
r_buffer_size = current_packet.packet->dataLength - 8;
|
||||
|
||||
return OK;
|
||||
}
|
||||
|
@ -549,11 +548,10 @@ Error NetworkedMultiplayerENet::put_packet(const uint8_t *p_buffer, int p_buffer
|
|||
}
|
||||
}
|
||||
|
||||
ENetPacket *packet = enet_packet_create(NULL, p_buffer_size + 12, packet_flags);
|
||||
ENetPacket *packet = enet_packet_create(NULL, p_buffer_size + 8, packet_flags);
|
||||
encode_uint32(unique_id, &packet->data[0]); // Source ID
|
||||
encode_uint32(target_peer, &packet->data[4]); // Dest ID
|
||||
encode_uint32(packet_flags, &packet->data[8]); // Dest ID
|
||||
copymem(&packet->data[12], p_buffer, p_buffer_size);
|
||||
copymem(&packet->data[8], p_buffer, p_buffer_size);
|
||||
|
||||
if (server) {
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue