/*
* 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 .
*/
#include "SpellPackets.h"
#include "CharacterPackets.h"
#include "MovementPackets.h"
#include "PacketOperators.h"
namespace WorldPackets::Spells
{
void CancelAura::Read()
{
_worldPacket >> SpellID;
_worldPacket >> CasterGUID;
}
void CancelChannelling::Read()
{
_worldPacket >> ChannelSpell;
_worldPacket >> Reason;
}
void CancelModSpeedNoControlAuras::Read()
{
_worldPacket >> TargetGUID;
}
void PetCancelAura::Read()
{
_worldPacket >> PetGUID;
_worldPacket >> SpellID;
}
WorldPacket const* SendKnownSpells::Write()
{
_worldPacket.reserve(1 + 4 * KnownSpells.size() + 4 * FavoriteSpells.size());
_worldPacket << Bits<1>(InitialLogin);
_worldPacket << Size(KnownSpells);
_worldPacket << Size(FavoriteSpells);
for (uint32 spellId : KnownSpells)
_worldPacket << uint32(spellId);
for (uint32 spellId : FavoriteSpells)
_worldPacket << uint32(spellId);
return &_worldPacket;
}
WorldPacket const* UpdateActionButtons::Write()
{
_worldPacket.append(ActionButtons.data(), ActionButtons.size());
_worldPacket << Reason;
return &_worldPacket;
}
void SetActionButton::Read()
{
_worldPacket >> Action;
_worldPacket >> Index;
}
WorldPacket const* SendUnlearnSpells::Write()
{
_worldPacket << Size(Spells);
for (uint32 spellId : Spells)
_worldPacket << uint32(spellId);
return &_worldPacket;
}
ByteBuffer& operator<<(ByteBuffer& data, AuraDataInfo const& auraData)
{
data << auraData.CastID;
data << int32(auraData.SpellID);
data << auraData.Visual;
data << uint16(auraData.Flags);
data << uint32(auraData.ActiveFlags);
data << uint16(auraData.CastLevel);
data << uint8(auraData.Applications);
data << int32(auraData.ContentTuningID);
data << auraData.DstLocation;
data << OptionalInit(auraData.CastUnit);
data << OptionalInit(auraData.CastItem);
data << OptionalInit(auraData.Duration);
data << OptionalInit(auraData.Remaining);
data << OptionalInit(auraData.TimeMod);
data << BitsSize<6>(auraData.Points);
data << BitsSize<6>(auraData.EstimatedPoints);
data << OptionalInit(auraData.ContentTuning);
if (auraData.ContentTuning)
data << *auraData.ContentTuning;
if (auraData.CastUnit)
data << *auraData.CastUnit;
if (auraData.CastItem)
data << *auraData.CastItem;
if (auraData.Duration)
data << uint32(*auraData.Duration);
if (auraData.Remaining)
data << uint32(*auraData.Remaining);
if (auraData.TimeMod)
data << float(*auraData.TimeMod);
if (!auraData.Points.empty())
data.append(auraData.Points.data(), auraData.Points.size());
if (!auraData.EstimatedPoints.empty())
data.append(auraData.EstimatedPoints.data(), auraData.EstimatedPoints.size());
return data;
}
ByteBuffer& operator<<(ByteBuffer& data, AuraInfo const& aura)
{
data << uint16(aura.Slot);
data << OptionalInit(aura.AuraData);
data.FlushBits();
if (aura.AuraData)
data << *aura.AuraData;
return data;
}
WorldPacket const* AuraUpdate::Write()
{
_worldPacket << Bits<1>(UpdateAll);
_worldPacket << BitsSize<9>(Auras);
for (AuraInfo const& aura : Auras)
_worldPacket << aura;
_worldPacket << UnitGUID;
return &_worldPacket;
}
ByteBuffer& operator>>(ByteBuffer& buffer, TargetLocation& location)
{
buffer >> location.Transport;
buffer >> location.Location;
return buffer;
}
ByteBuffer& operator>>(ByteBuffer& buffer, SpellTargetData& targetData)
{
buffer >> targetData.Flags;
buffer >> targetData.Unit;
buffer >> targetData.Item;
buffer >> targetData.Unknown1127_1;
buffer >> Bits<1>(targetData.Unknown1127_2);
buffer >> OptionalInit(targetData.SrcLocation);
buffer >> OptionalInit(targetData.DstLocation);
buffer >> OptionalInit(targetData.Orientation);
buffer >> OptionalInit(targetData.MapID);
buffer >> SizedString::BitsSize<7>(targetData.Name);
if (targetData.SrcLocation)
buffer >> *targetData.SrcLocation;
if (targetData.DstLocation)
buffer >> *targetData.DstLocation;
if (targetData.Orientation)
buffer >> *targetData.Orientation;
if (targetData.MapID)
buffer >> *targetData.MapID;
buffer >> SizedString::Data(targetData.Name);
return buffer;
}
ByteBuffer& operator>>(ByteBuffer& buffer, MissileTrajectoryRequest& trajectory)
{
buffer >> trajectory.Pitch;
buffer >> trajectory.Speed;
return buffer;
}
ByteBuffer& operator>>(ByteBuffer& data, SpellCraftingReagent& optionalReagent)
{
data >> optionalReagent.ItemID;
data >> optionalReagent.DataSlotIndex;
data >> optionalReagent.Quantity;
data >> OptionalInit(optionalReagent.Source);
if (optionalReagent.Source)
data >> *optionalReagent.Source;
return data;
}
ByteBuffer& operator>>(ByteBuffer& data, SpellExtraCurrencyCost& extraCurrencyCost)
{
data >> extraCurrencyCost.CurrencyID;
data >> extraCurrencyCost.Count;
return data;
}
ByteBuffer& operator>>(ByteBuffer& buffer, SpellCastRequest& request)
{
buffer >> request.CastID;
buffer >> request.SendCastFlags;
buffer >> request.Misc[0];
buffer >> request.Misc[1];
buffer >> request.SpellID;
buffer >> request.Visual;
buffer >> request.MissileTrajectory;
buffer >> request.CraftingNPC;
buffer >> Size(request.OptionalCurrencies);
buffer >> Size(request.OptionalReagents);
buffer >> Size(request.RemovedModifications);
buffer >> request.CraftingFlags;
for (SpellExtraCurrencyCost& optionalCurrency : request.OptionalCurrencies)
buffer >> optionalCurrency;
buffer >> request.Target;
buffer.ResetBitPos();
buffer >> OptionalInit(request.MoveUpdate);
buffer >> BitsSize<2>(request.Weight);
buffer >> OptionalInit(request.CraftingOrderID);
for (SpellCraftingReagent& optionalReagent : request.OptionalReagents)
buffer >> optionalReagent;
if (request.CraftingOrderID)
buffer >> *request.CraftingOrderID;
for (SpellCraftingReagent& optionalReagent : request.RemovedModifications)
buffer >> optionalReagent;
if (request.MoveUpdate)
buffer >> *request.MoveUpdate;
for (SpellWeight& weight : request.Weight)
{
buffer.ResetBitPos();
buffer >> Bits<2>(weight.Type);
buffer >> weight.ID;
buffer >> weight.Quantity;
}
return buffer;
}
void CastSpell::Read()
{
_worldPacket >> Cast;
}
void PetCastSpell::Read()
{
_worldPacket >> PetGUID;
_worldPacket >> Cast;
}
void UseItem::Read()
{
_worldPacket >> PackSlot;
_worldPacket >> Slot;
_worldPacket >> CastItem;
_worldPacket >> Cast;
}
WorldPacket const* SpellPrepare::Write()
{
_worldPacket << ClientCastID;
_worldPacket << ServerCastID;
return &_worldPacket;
}
ByteBuffer& operator<<(ByteBuffer& data, TargetLocation const& targetLocation)
{
data << targetLocation.Transport;
data << targetLocation.Location;
return data;
}
ByteBuffer& operator<<(ByteBuffer& data, SpellTargetData const& spellTargetData)
{
data << uint32(spellTargetData.Flags);
data << spellTargetData.Unit;
data << spellTargetData.Item;
data << spellTargetData.Unknown1127_1;
data << Bits<1>(spellTargetData.Unknown1127_2);
data << OptionalInit(spellTargetData.SrcLocation);
data << OptionalInit(spellTargetData.DstLocation);
data << OptionalInit(spellTargetData.Orientation);
data << OptionalInit(spellTargetData.MapID);
data << SizedString::BitsSize<7>(spellTargetData.Name);
data.FlushBits();
if (spellTargetData.SrcLocation)
data << *spellTargetData.SrcLocation;
if (spellTargetData.DstLocation)
data << *spellTargetData.DstLocation;
if (spellTargetData.Orientation)
data << float(*spellTargetData.Orientation);
if (spellTargetData.MapID)
data << int32(*spellTargetData.MapID);
data << SizedString::Data(spellTargetData.Name);
return data;
}
ByteBuffer& operator<<(ByteBuffer& data, SpellMissStatus const& spellMissStatus)
{
data << uint8(spellMissStatus.Reason);
if (spellMissStatus.Reason == SPELL_MISS_REFLECT)
data << uint8(spellMissStatus.ReflectStatus);
return data;
}
ByteBuffer& operator<<(ByteBuffer& data, SpellHitStatus const& spellHitStatus)
{
data << uint8(spellHitStatus.Reason);
return data;
}
ByteBuffer& operator<<(ByteBuffer& data, SpellPowerData const& spellPowerData)
{
data << int8(spellPowerData.Type);
data << int32(spellPowerData.Cost);
return data;
}
ByteBuffer& operator<<(ByteBuffer& data, RuneData const& runeData)
{
data << uint8(runeData.Start);
data << uint8(runeData.Count);
data << Size(runeData.Cooldowns);
if (!runeData.Cooldowns.empty())
data.append(runeData.Cooldowns.data(), runeData.Cooldowns.size());
return data;
}
ByteBuffer& operator<<(ByteBuffer& data, MissileTrajectoryResult const& missileTrajectory)
{
data << uint32(missileTrajectory.TravelTime);
data << float(missileTrajectory.Pitch);
return data;
}
ByteBuffer& operator<<(ByteBuffer& data, CreatureImmunities const& immunities)
{
data << int32(immunities.School);
data << int32(immunities.Value);
return data;
}
ByteBuffer& operator<<(ByteBuffer& data, SpellHealPrediction const& spellPred)
{
data << int32(spellPred.Points);
data << uint32(spellPred.Type);
data << spellPred.BeaconGUID;
return data;
}
ByteBuffer& operator<<(ByteBuffer& data, SpellCastData const& spellCastData)
{
data << spellCastData.CasterGUID;
data << spellCastData.CasterUnit;
data << spellCastData.CastID;
data << spellCastData.OriginalCastID;
data << int32(spellCastData.SpellID);
data << spellCastData.Visual;
data << uint32(spellCastData.CastFlags);
data << uint32(spellCastData.CastFlagsEx);
data << uint32(spellCastData.CastFlagsEx2);
data << uint32(spellCastData.CastTime);
data << spellCastData.MissileTrajectory;
data << int32(spellCastData.AmmoDisplayID);
data << uint8(spellCastData.DestLocSpellCastIndex);
data << spellCastData.Immunities;
data << spellCastData.Predict;
data << BitsSize<16>(spellCastData.HitTargets);
data << BitsSize<16>(spellCastData.MissTargets);
data << BitsSize<16>(spellCastData.HitStatus);
data << BitsSize<16>(spellCastData.MissStatus);
data << BitsSize<9>(spellCastData.RemainingPower);
data << OptionalInit(spellCastData.RemainingRunes);
data << BitsSize<16>(spellCastData.TargetPoints);
data.FlushBits();
data << spellCastData.Target;
for (ObjectGuid const& hitTarget : spellCastData.HitTargets)
data << hitTarget;
for (ObjectGuid const& missTarget : spellCastData.MissTargets)
data << missTarget;
for (SpellHitStatus const& hitStatus : spellCastData.HitStatus)
data << hitStatus;
for (SpellMissStatus const& missStatus : spellCastData.MissStatus)
data << missStatus;
for (SpellPowerData const& power : spellCastData.RemainingPower)
data << power;
if (spellCastData.RemainingRunes)
data << *spellCastData.RemainingRunes;
for (TargetLocation const& targetLoc : spellCastData.TargetPoints)
data << targetLoc;
return data;
}
WorldPacket const* SpellStart::Write()
{
_worldPacket << Cast;
return &_worldPacket;
}
WorldPacket const* SpellGo::Write()
{
*this << Cast;
WriteLogDataBit();
FlushBits();
WriteLogData();
return &_worldPacket;
}
ByteBuffer& operator<<(ByteBuffer& data, LearnedSpellInfo const& learnedSpellInfo)
{
data << int32(learnedSpellInfo.SpellID);
data << Bits<1>(learnedSpellInfo.Favorite);
data << OptionalInit(learnedSpellInfo.EquipableSpellInvSlot);
data << OptionalInit(learnedSpellInfo.Superceded);
data << OptionalInit(learnedSpellInfo.TraitDefinitionID);
data.FlushBits();
if (learnedSpellInfo.EquipableSpellInvSlot)
data << int32(*learnedSpellInfo.EquipableSpellInvSlot);
if (learnedSpellInfo.Superceded)
data << int32(*learnedSpellInfo.Superceded);
if (learnedSpellInfo.TraitDefinitionID)
data << int32(*learnedSpellInfo.TraitDefinitionID);
return data;
}
WorldPacket const* LearnedSpells::Write()
{
_worldPacket << Size(ClientLearnedSpellData);
_worldPacket << uint32(SpecializationID);
_worldPacket << Bits<1>(SuppressMessaging);
_worldPacket.FlushBits();
for (LearnedSpellInfo const& spell : ClientLearnedSpellData)
_worldPacket << spell;
return &_worldPacket;
}
WorldPacket const* SupercededSpells::Write()
{
_worldPacket << Size(ClientLearnedSpellData);
for (LearnedSpellInfo const& spell : ClientLearnedSpellData)
_worldPacket << spell;
return &_worldPacket;
}
WorldPacket const* SpellFailure::Write()
{
_worldPacket << CasterUnit;
_worldPacket << CastID;
_worldPacket << int32(SpellID);
_worldPacket << Visual;
_worldPacket << uint16(Reason);
return &_worldPacket;
}
WorldPacket const* SpellFailedOther::Write()
{
_worldPacket << CasterUnit;
_worldPacket << CastID;
_worldPacket << uint32(SpellID);
_worldPacket << Visual;
_worldPacket << uint8(Reason);
return &_worldPacket;
}
WorldPacket const* CastFailed::Write()
{
_worldPacket << CastID;
_worldPacket << int32(SpellID);
_worldPacket << Visual;
_worldPacket << int32(Reason);
_worldPacket << int32(FailedArg1);
_worldPacket << int32(FailedArg2);
return &_worldPacket;
}
WorldPacket const* PetCastFailed::Write()
{
_worldPacket << CastID;
_worldPacket << int32(SpellID);
_worldPacket << int32(Reason);
_worldPacket << int32(FailedArg1);
_worldPacket << int32(FailedArg2);
return &_worldPacket;
}
ByteBuffer& operator<<(ByteBuffer& data, SpellModifierData const& spellModifierData)
{
data << float(spellModifierData.ModifierValue);
data << uint8(spellModifierData.ClassIndex);
return data;
}
ByteBuffer& operator<<(ByteBuffer& data, SpellModifier const& spellModifier)
{
data << uint8(spellModifier.ModIndex);
data << Size(spellModifier.ModifierData);
for (SpellModifierData const& modData : spellModifier.ModifierData)
data << modData;
return data;
}
WorldPacket const* SetSpellModifier::Write()
{
_worldPacket << Size(Modifiers);
for (SpellModifier const& spellMod : Modifiers)
_worldPacket << spellMod;
return &_worldPacket;
}
WorldPacket const* UnlearnedSpells::Write()
{
_worldPacket << Size(SpellID);
for (uint32 spellId : SpellID)
_worldPacket << uint32(spellId);
_worldPacket << Bits<1>(SuppressMessaging);
_worldPacket.FlushBits();
return &_worldPacket;
}
WorldPacket const* CooldownEvent::Write()
{
_worldPacket << int32(SpellID);
_worldPacket << Bits<1>(IsPet);
_worldPacket.FlushBits();
return &_worldPacket;
}
WorldPacket const* ClearCooldowns::Write()
{
_worldPacket << Size(SpellID);
if (!SpellID.empty())
_worldPacket.append(SpellID.data(), SpellID.size());
_worldPacket << Bits<1>(IsPet);
_worldPacket.FlushBits();
return &_worldPacket;
}
WorldPacket const* ClearCooldown::Write()
{
_worldPacket << uint32(SpellID);
_worldPacket << Bits<1>(ClearOnHold);
_worldPacket << Bits<1>(IsPet);
_worldPacket.FlushBits();
return &_worldPacket;
}
WorldPacket const* ModifyCooldown::Write()
{
_worldPacket << int32(SpellID);
_worldPacket << int32(DeltaTime);
_worldPacket << Bits<1>(IsPet);
_worldPacket << Bits<1>(SkipCategory);
_worldPacket.FlushBits();
return &_worldPacket;
}
WorldPacket const* UpdateCooldown::Write()
{
_worldPacket << int32(SpellID);
_worldPacket << float(ModChange);
_worldPacket << float(ModRate);
return &_worldPacket;
}
ByteBuffer& operator<<(ByteBuffer& data, SpellCooldownStruct const& cooldown)
{
data << uint32(cooldown.SrecID);
data << uint32(cooldown.ForcedCooldown);
data << float(cooldown.ModRate);
return data;
}
WorldPacket const* SpellCooldown::Write()
{
_worldPacket << Caster;
_worldPacket << uint8(Flags);
_worldPacket << Size(SpellCooldowns);
for (SpellCooldownStruct const& cooldown : SpellCooldowns)
_worldPacket << cooldown;
return &_worldPacket;
}
ByteBuffer& operator<<(ByteBuffer& data, SpellHistoryEntry const& historyEntry)
{
data << uint32(historyEntry.SpellID);
data << uint32(historyEntry.ItemID);
data << uint32(historyEntry.Category);
data << int32(historyEntry.RecoveryTime);
data << int32(historyEntry.CategoryRecoveryTime);
data << float(historyEntry.ModRate);
data << OptionalInit(historyEntry.RecoveryTimeStartOffset);
data << OptionalInit(historyEntry.CategoryRecoveryTimeStartOffset);
data << Bits<1>(historyEntry.OnHold);
data.FlushBits();
if (historyEntry.RecoveryTimeStartOffset)
data << uint32(*historyEntry.RecoveryTimeStartOffset);
if (historyEntry.CategoryRecoveryTimeStartOffset)
data << uint32(*historyEntry.CategoryRecoveryTimeStartOffset);
return data;
}
WorldPacket const* SendSpellHistory::Write()
{
_worldPacket << Size(Entries);
for (SpellHistoryEntry const& historyEntry : Entries)
_worldPacket << historyEntry;
return &_worldPacket;
}
WorldPacket const* ClearAllSpellCharges::Write()
{
_worldPacket << Bits<1>(IsPet);
_worldPacket.FlushBits();
return &_worldPacket;
}
WorldPacket const* ClearSpellCharges::Write()
{
_worldPacket << int32(Category);
_worldPacket << Bits<1>(IsPet);
_worldPacket.FlushBits();
return &_worldPacket;
}
WorldPacket const* SetSpellCharges::Write()
{
_worldPacket << int32(Category);
_worldPacket << uint32(NextRecoveryTime);
_worldPacket << uint8(ConsumedCharges);
_worldPacket << float(ChargeModRate);
_worldPacket << Bits<1>(IsPet);
_worldPacket.FlushBits();
return &_worldPacket;
}
WorldPacket const* UpdateChargeCategoryCooldown::Write()
{
_worldPacket << int32(Category);
_worldPacket << float(ModChange);
_worldPacket << float(ModRate);
_worldPacket << Bits<1>(Snapshot);
_worldPacket.FlushBits();
return &_worldPacket;
}
ByteBuffer& operator<<(ByteBuffer& data, SpellChargeEntry const& chargeEntry)
{
data << uint32(chargeEntry.Category);
data << uint32(chargeEntry.NextRecoveryTime);
data << float(chargeEntry.ChargeModRate);
data << uint8(chargeEntry.ConsumedCharges);
return data;
}
WorldPacket const* SendSpellCharges::Write()
{
_worldPacket << Size(Entries);
for (SpellChargeEntry const& chargeEntry : Entries)
_worldPacket << chargeEntry;
return &_worldPacket;
}
WorldPacket const* ClearTarget::Write()
{
_worldPacket << Guid;
return &_worldPacket;
}
WorldPacket const* CancelOrphanSpellVisual::Write()
{
_worldPacket << int32(SpellVisualID);
return &_worldPacket;
}
WorldPacket const* CancelSpellVisual::Write()
{
_worldPacket << Source;
_worldPacket << int32(SpellVisualID);
return &_worldPacket;
}
WorldPacket const* CancelSpellVisualKit::Write()
{
_worldPacket << Source;
_worldPacket << int32(SpellVisualKitID);
_worldPacket << Bits<1>(MountedVisual);
_worldPacket.FlushBits();
return &_worldPacket;
}
WorldPacket const* PlayOrphanSpellVisual::Write()
{
_worldPacket << SourceLocation;
_worldPacket << SourceRotation;
_worldPacket << TargetLocation;
_worldPacket << Target;
_worldPacket << TargetTransport;
_worldPacket << int32(SpellVisualID);
_worldPacket << float(TravelSpeed);
_worldPacket << float(LaunchDelay);
_worldPacket << float(MinDuration);
_worldPacket << Bits<1>(SpeedAsTime);
_worldPacket.FlushBits();
return &_worldPacket;
}
WorldPacket const* PlaySpellVisual::Write()
{
_worldPacket << Source;
_worldPacket << Target;
_worldPacket << Transport;
_worldPacket << TargetPosition;
_worldPacket << uint32(SpellVisualID);
_worldPacket << float(TravelSpeed);
_worldPacket << uint8(HitReason);
_worldPacket << uint8(MissReason);
_worldPacket << uint8(ReflectStatus);
_worldPacket << float(LaunchDelay);
_worldPacket << float(MinDuration);
_worldPacket << Bits<1>(SpeedAsTime);
_worldPacket.FlushBits();
return &_worldPacket;
}
WorldPacket const* PlaySpellVisualKit::Write()
{
_worldPacket << Unit;
_worldPacket << int32(KitRecID);
_worldPacket << int32(KitType);
_worldPacket << uint32(Duration);
_worldPacket << Bits<1>(MountedVisual);
_worldPacket.FlushBits();
return &_worldPacket;
}
WorldPacket const* SpellVisualLoadScreen::Write()
{
_worldPacket << int32(SpellVisualKitID);
_worldPacket << int32(Delay);
return &_worldPacket;
}
void CancelCast::Read()
{
_worldPacket >> CastID;
_worldPacket >> SpellID;
}
void OpenItem::Read()
{
_worldPacket >> Slot
>> PackSlot;
}
ByteBuffer& operator<<(ByteBuffer& data, SpellChannelStartInterruptImmunities const& interruptImmunities)
{
data << int32(interruptImmunities.SchoolImmunities);
data << int32(interruptImmunities.Immunities);
return data;
}
ByteBuffer& operator<<(ByteBuffer& data, SpellTargetedHealPrediction const& targetedHealPrediction)
{
data << targetedHealPrediction.TargetGUID;
data << targetedHealPrediction.Predict;
return data;
}
WorldPacket const* SpellChannelStart::Write()
{
_worldPacket << CasterGUID;
_worldPacket << int32(SpellID);
_worldPacket << Visual;
_worldPacket << uint32(ChannelDuration);
_worldPacket << OptionalInit(InterruptImmunities);
_worldPacket << OptionalInit(HealPrediction);
_worldPacket.FlushBits();
if (InterruptImmunities)
_worldPacket << *InterruptImmunities;
if (HealPrediction)
_worldPacket << *HealPrediction;
return &_worldPacket;
}
WorldPacket const* SpellChannelUpdate::Write()
{
_worldPacket << CasterGUID;
_worldPacket << int32(TimeRemaining);
return &_worldPacket;
}
WorldPacket const* SpellEmpowerStart::Write()
{
_worldPacket << CastID;
_worldPacket << CasterGUID;
_worldPacket << Size(Targets);
_worldPacket << int32(SpellID);
_worldPacket << Visual;
_worldPacket << EmpowerDuration;
_worldPacket << MinHoldTime;
_worldPacket << HoldAtMaxTime;
_worldPacket << Size(StageDurations);
for (ObjectGuid const& target : Targets)
_worldPacket << target;
for (Duration stageDuration : StageDurations)
_worldPacket << stageDuration;
_worldPacket << OptionalInit(InterruptImmunities);
_worldPacket << OptionalInit(HealPrediction);
_worldPacket.FlushBits();
if (InterruptImmunities)
_worldPacket << *InterruptImmunities;
if (HealPrediction)
_worldPacket << *HealPrediction;
return &_worldPacket;
}
WorldPacket const* SpellEmpowerUpdate::Write()
{
_worldPacket << CastID;
_worldPacket << CasterGUID;
_worldPacket << TimeRemaining;
_worldPacket << Size(StageDurations);
_worldPacket << uint8(Status);
_worldPacket.FlushBits();
for (Duration stageDuration : StageDurations)
_worldPacket << stageDuration;
return &_worldPacket;
}
void SetEmpowerMinHoldStagePercent::Read()
{
_worldPacket >> MinHoldStagePercent;
}
void SpellEmpowerRelease::Read()
{
_worldPacket >> SpellID;
}
void SpellEmpowerRestart::Read()
{
_worldPacket >> SpellID;
}
WorldPacket const* SpellEmpowerSetStage::Write()
{
_worldPacket << CastID;
_worldPacket << CasterGUID;
_worldPacket << int32(Stage);
return &_worldPacket;
}
WorldPacket const* ResurrectRequest::Write()
{
_worldPacket << ResurrectOffererGUID;
_worldPacket << uint32(ResurrectOffererVirtualRealmAddress);
_worldPacket << uint32(PetNumber);
_worldPacket << int32(SpellID);
_worldPacket << SizedString::BitsSize<11>(Name);
_worldPacket << Bits<1>(UseTimer);
_worldPacket << Bits<1>(Sickness);
_worldPacket.FlushBits();
_worldPacket << SizedString::Data(Name);
return &_worldPacket;
}
void UnlearnSkill::Read()
{
_worldPacket >> SkillLine;
}
void SelfRes::Read()
{
_worldPacket >> SpellID;
}
void GetMirrorImageData::Read()
{
_worldPacket >> UnitGUID;
}
MirrorImageComponentedData::MirrorImageComponentedData()
: ServerPacket(SMSG_MIRROR_IMAGE_COMPONENTED_DATA, 8 + 4 + 8 * 1 + 8 + 11 * 4)
{
}
MirrorImageComponentedData::~MirrorImageComponentedData() = default;
WorldPacket const* MirrorImageComponentedData::Write()
{
_worldPacket << UnitGUID;
_worldPacket << int32(ChrModelID);
_worldPacket << uint8(RaceID);
_worldPacket << uint8(Gender);
_worldPacket << uint8(ClassID);
_worldPacket << Size(Customizations);
_worldPacket << GuildGUID;
_worldPacket << Size(ItemDisplayID);
_worldPacket << int32(SpellVisualKitID);
_worldPacket << int32(Unused_1115);
for (Character::ChrCustomizationChoice const& customization : Customizations)
_worldPacket << customization;
for (int32 itemDisplayId : ItemDisplayID)
_worldPacket << int32(itemDisplayId);
return &_worldPacket;
}
WorldPacket const* MirrorImageCreatureData::Write()
{
_worldPacket << UnitGUID;
_worldPacket << int32(DisplayID);
_worldPacket << int32(SpellVisualKitID);
return &_worldPacket;
}
void SpellClick::Read()
{
_worldPacket >> SpellClickUnitGuid;
_worldPacket >> Bits<1>(TryAutoDismount);
}
WorldPacket const* ResyncRunes::Write()
{
_worldPacket << Runes;
return &_worldPacket;
}
WorldPacket const* AddRunePower::Write()
{
_worldPacket << uint32(AddedRunesMask);
return &_worldPacket;
}
void MissileTrajectoryCollision::Read()
{
_worldPacket >> Target;
_worldPacket >> SpellID;
_worldPacket >> CastID;
_worldPacket >> CollisionPos;
}
WorldPacket const* NotifyMissileTrajectoryCollision::Write()
{
_worldPacket << Caster;
_worldPacket << CastID;
_worldPacket << CollisionPos;
return &_worldPacket;
}
void UpdateMissileTrajectory::Read()
{
_worldPacket >> Guid;
_worldPacket >> CastID;
_worldPacket >> MoveMsgID;
_worldPacket >> SpellID;
_worldPacket >> Pitch;
_worldPacket >> Speed;
_worldPacket >> FirePos;
_worldPacket >> ImpactPos;
_worldPacket >> OptionalInit(Status);
_worldPacket.ResetBitPos();
if (Status)
_worldPacket >> *Status;
}
void UpdateAuraVisual::Read()
{
_worldPacket >> SpellID;
_worldPacket >> Visual;
_worldPacket >> TargetGUID;
}
WorldPacket const* SpellDelayed::Write()
{
_worldPacket << Caster;
_worldPacket << uint32(ActualDelay);
return &_worldPacket;
}
WorldPacket const* DispelFailed::Write()
{
_worldPacket << CasterGUID;
_worldPacket << VictimGUID;
_worldPacket << uint32(SpellID);
_worldPacket << Size(FailedSpells);
if (!FailedSpells.empty())
_worldPacket.append(FailedSpells.data(), FailedSpells.size());
return &_worldPacket;
}
WorldPacket const* CustomLoadScreen::Write()
{
_worldPacket << uint32(TeleportSpellID);
_worldPacket << uint32(LoadingScreenID);
return &_worldPacket;
}
WorldPacket const* MountResult::Write()
{
_worldPacket << int32(Result);
return &_worldPacket;
}
WorldPacket const* ApplyMountEquipmentResult::Write()
{
_worldPacket << ItemGUID;
_worldPacket << int32(ItemID);
_worldPacket << Bits<1>(Result);
_worldPacket.FlushBits();
return &_worldPacket;
}
WorldPacket const* MissileCancel::Write()
{
_worldPacket << OwnerGUID;
_worldPacket << int32(SpellID);
_worldPacket << Bits<1>(Reverse);
_worldPacket.FlushBits();
return &_worldPacket;
}
void TradeSkillSetFavorite::Read()
{
_worldPacket >> RecipeID;
_worldPacket >> Bits<1>(IsFavorite);
}
void KeyboundOverride::Read()
{
_worldPacket >> OverrideID;
}
}