diff options
| author | Ovahlord <dreadkiller@gmx.de> | 2019-05-30 19:01:56 +0200 |
|---|---|---|
| committer | Peter Keresztes Schmidt <carbenium@outlook.com> | 2020-08-06 21:48:51 +0200 |
| commit | 86107584c02a6f94292fb8f4c2767437aadd673a (patch) | |
| tree | d2561196100d82c8e403afeccd7e3a7c49802508 /src/server/game/Server | |
| parent | db9072a183cd93014d708d67ae3a762fdbf5d095 (diff) | |
Core/Packets: updated CMSG_LFG_JOIN and CMSG_LFG_LEAVE to new packet handling
(cherry picked from commit 6abeb365842c506f2151e01e87e2981ee7ff0a7e)
# Conflicts:
# src/server/game/Handlers/LFGHandler.cpp
# src/server/game/Server/Packets/AllPackets.h
# src/server/game/Server/WorldSession.h
# src/server/game/Server/WorldSocket.cpp
Diffstat (limited to 'src/server/game/Server')
| -rw-r--r-- | src/server/game/Server/Packets/AllPackets.h | 1 | ||||
| -rw-r--r-- | src/server/game/Server/Packets/LFGPackets.cpp | 29 | ||||
| -rw-r--r-- | src/server/game/Server/Packets/LFGPackets.h | 47 | ||||
| -rw-r--r-- | src/server/game/Server/WorldSession.h | 9 |
4 files changed, 84 insertions, 2 deletions
diff --git a/src/server/game/Server/Packets/AllPackets.h b/src/server/game/Server/Packets/AllPackets.h index 5fb2c5b9e82..1b3d2006854 100644 --- a/src/server/game/Server/Packets/AllPackets.h +++ b/src/server/game/Server/Packets/AllPackets.h @@ -24,6 +24,7 @@ #include "CombatLogPackets.h" #include "CombatPackets.h" #include "GuildPackets.h" +#include "LFGPackets.h" #include "NPCPackets.h" #include "MiscPackets.h" #include "PetPackets.h" diff --git a/src/server/game/Server/Packets/LFGPackets.cpp b/src/server/game/Server/Packets/LFGPackets.cpp new file mode 100644 index 00000000000..a1e3e5e146a --- /dev/null +++ b/src/server/game/Server/Packets/LFGPackets.cpp @@ -0,0 +1,29 @@ +/* + * This file is part of the TrinityCore Project. See AUTHORS file for Copyright information + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by the + * Free Software Foundation; either version 2 of the License, or (at your + * option) any later version. + * + * This program is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for + * more details. + * + * You should have received a copy of the GNU General Public License along + * with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +#include "LFGPackets.h" + +void WorldPackets::LFG::LFGJoin::Read() +{ + _worldPacket >> Roles; + _worldPacket.read_skip<uint16>(); + Slots.resize(_worldPacket.read<uint8>()); + for (uint32& slot : Slots) + _worldPacket >> slot; + _worldPacket.read_skip<uint32>(); + _worldPacket >> Comment; +} diff --git a/src/server/game/Server/Packets/LFGPackets.h b/src/server/game/Server/Packets/LFGPackets.h new file mode 100644 index 00000000000..f04aa3a387b --- /dev/null +++ b/src/server/game/Server/Packets/LFGPackets.h @@ -0,0 +1,47 @@ +/* + * This file is part of the TrinityCore Project. See AUTHORS file for Copyright information + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by the + * Free Software Foundation; either version 2 of the License, or (at your + * option) any later version. + * + * This program is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for + * more details. + * + * You should have received a copy of the GNU General Public License along + * with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +#ifndef LFGPackets_h__ +#define LFGPackets_h__ + +#include "Packet.h" +#include "PacketUtilities.h" + +namespace WorldPackets::LFG +{ + class LFGJoin final : public ClientPacket + { + public: + LFGJoin(WorldPacket&& packet) : ClientPacket(CMSG_LFG_JOIN, std::move(packet)) { } + + void Read() override; + + uint32 Roles = 0; + Array<uint32, 50> Slots; + std::string Comment; + }; + + class LFGLeave final : public ClientPacket + { + public: + LFGLeave(WorldPacket&& packet) : ClientPacket(CMSG_LFG_LEAVE, std::move(packet)) { } + + void Read() override { }; + }; +} + +#endif // LFGPackets_h__ diff --git a/src/server/game/Server/WorldSession.h b/src/server/game/Server/WorldSession.h index f929c013030..33e863b15c5 100644 --- a/src/server/game/Server/WorldSession.h +++ b/src/server/game/Server/WorldSession.h @@ -141,6 +141,11 @@ namespace WorldPackets class GuildSetGuildMaster; class SaveGuildEmblem; } + namespace LFG + { + class LFGJoin; + class LFGLeave; + } namespace NPC { class Hello; @@ -980,8 +985,8 @@ class TC_GAME_API WorldSession void HandleLfgSetCommentOpcode(WorldPacket& recvData); void HandleLfgPlayerLockInfoRequestOpcode(WorldPacket& recvData); void HandleLfgPartyLockInfoRequestOpcode(WorldPacket& recvData); - void HandleLfgJoinOpcode(WorldPacket& recvData); - void HandleLfgLeaveOpcode(WorldPacket& recvData); + void HandleLfgJoinOpcode(WorldPackets::LFG::LFGJoin& lfgJoin); + void HandleLfgLeaveOpcode(WorldPackets::LFG::LFGLeave& lfgleave); void HandleLfgSetRolesOpcode(WorldPacket& recvData); void HandleLfgProposalResultOpcode(WorldPacket& recvData); void HandleLfgSetBootVoteOpcode(WorldPacket& recvData); |
