mirror of
https://github.com/Kelsidavis/WoWee.git
synced 2026-03-22 23:30:14 +00:00
fix(combatlog): parse classic spell damage shield GUIDs as packed
This commit is contained in:
parent
468880e2c8
commit
b059bbcf89
1 changed files with 16 additions and 7 deletions
|
|
@ -6170,23 +6170,32 @@ void GameHandler::handlePacket(network::Packet& packet) {
|
|||
|
||||
// ---- Spell combat logs (consume) ----
|
||||
case Opcode::SMSG_SPELLDAMAGESHIELD: {
|
||||
// Classic/TBC: uint64 victim + uint64 caster + spellId(4) + damage(4) + schoolMask(4)
|
||||
// WotLK: packed_guid victim + packed_guid caster + spellId(4) + damage(4) + absorbed(4) + schoolMask(4)
|
||||
const bool shieldClassicLike = isClassicLikeExpansion() || isActiveExpansion("tbc");
|
||||
const size_t shieldMinSz = shieldClassicLike ? 24u : 2u;
|
||||
// Classic: packed_guid victim + packed_guid caster + spellId(4) + damage(4) + schoolMask(4)
|
||||
// TBC: uint64 victim + uint64 caster + spellId(4) + damage(4) + schoolMask(4)
|
||||
// WotLK: packed_guid victim + packed_guid caster + spellId(4) + damage(4) + absorbed(4) + schoolMask(4)
|
||||
const bool shieldTbc = isActiveExpansion("tbc");
|
||||
const bool shieldWotlkLike = !isClassicLikeExpansion() && !shieldTbc;
|
||||
const size_t shieldMinSz = shieldTbc ? 24u : 2u;
|
||||
if (packet.getSize() - packet.getReadPos() < shieldMinSz) {
|
||||
packet.setReadPos(packet.getSize()); break;
|
||||
}
|
||||
uint64_t victimGuid = shieldClassicLike
|
||||
if (!shieldTbc && (!hasFullPackedGuid(packet))) {
|
||||
packet.setReadPos(packet.getSize()); break;
|
||||
}
|
||||
uint64_t victimGuid = shieldTbc
|
||||
? packet.readUInt64() : UpdateObjectParser::readPackedGuid(packet);
|
||||
uint64_t casterGuid = shieldClassicLike
|
||||
if (packet.getSize() - packet.getReadPos() < (shieldTbc ? 8u : 1u)
|
||||
|| (!shieldTbc && !hasFullPackedGuid(packet))) {
|
||||
packet.setReadPos(packet.getSize()); break;
|
||||
}
|
||||
uint64_t casterGuid = shieldTbc
|
||||
? packet.readUInt64() : UpdateObjectParser::readPackedGuid(packet);
|
||||
if (packet.getSize() - packet.getReadPos() < 12) {
|
||||
packet.setReadPos(packet.getSize()); break;
|
||||
}
|
||||
uint32_t shieldSpellId = packet.readUInt32();
|
||||
uint32_t damage = packet.readUInt32();
|
||||
if (!shieldClassicLike && packet.getSize() - packet.getReadPos() >= 4)
|
||||
if (shieldWotlkLike && packet.getSize() - packet.getReadPos() >= 4)
|
||||
/*uint32_t absorbed =*/ packet.readUInt32();
|
||||
/*uint32_t school =*/ packet.readUInt32();
|
||||
// Show combat text: damage shield reflect
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue