Compare commits

..

1 Commits

Author SHA1 Message Date
1c979a76b6
Merge 02a5632147 into 8568fd1c46 2024-10-27 09:50:51 +01:00

View File

@ -95,11 +95,12 @@ static void sendAroundPacket(const EntityRef recipient, std::vector<std::vector<
for (size_t i = 0; i < count; i++) {
data[i] = slice[i];
}
recipient.sock->sendPacket(pktBuf, packetId, sizeof(int32_t) + (count * sizeof(T)));
recipient.sock->sendPacket(pktBuf, packetId, 4 + (count * sizeof(T)));
}
}
static void sendAroundDelPacket(const EntityRef recipient, std::vector<std::vector<int32_t>>& slices, bool isTransportation, uint32_t packetId) {
template<class T>
static void sendAroundDelPacket(const EntityRef recipient, std::vector<std::vector<T>>& slices, bool isTransportation, uint32_t packetId) {
assert(recipient.kind == EntityKind::PLAYER);
size_t maxCnt = MAX_IDS_PER_AROUND_DEL;
@ -112,22 +113,20 @@ static void sendAroundDelPacket(const EntityRef recipient, std::vector<std::vect
int count = slice.size();
assert(count <= maxCnt);
size_t baseSize;
T* data;
if (isTransportation) {
sP_FE2CL_AROUND_DEL_TRANSPORTATION* pkt = (sP_FE2CL_AROUND_DEL_TRANSPORTATION*)pktBuf;
pkt->eTT = 3;
pkt->iCnt = count;
baseSize = sizeof(sP_FE2CL_AROUND_DEL_TRANSPORTATION);
*((int32_t*)pktBuf) = 3; // eTT
*((int32_t*)pktBuf + sizeof(int32_t)) = count;
data = (T*)(pktBuf + sizeof(int32_t) + sizeof(int32_t));
} else {
*((int32_t*)pktBuf) = count;
baseSize = sizeof(int32_t);
data = (T*)(pktBuf + sizeof(int32_t));
}
int32_t* ids = (int32_t*)(pktBuf + baseSize);
for (size_t i = 0; i < count; i++) {
ids[i] = slice[i];
data[i] = slice[i];
}
recipient.sock->sendPacket(pktBuf, packetId, baseSize + (count * sizeof(int32_t)));
recipient.sock->sendPacket(pktBuf, packetId, isTransportation ? 8 : 4 + (count * sizeof(T)));
}
}