- Create an entry for the spell in /code/PVPW_SpellMap.lua and the matching category
- Create an entry in /example-events/[category] and gather a mtaching event
- Create a sound file /assets/sounds/[language]/[category]/[spellName].mp3
- Add sound test /test/PVPW_TestSound[category][language].lua
- Add combat test /test/PVPW_TestCombatEvents[category][language].lua
- Create an entry for the spell in /code/PVPW_SpellAvoidMap.lua and the matching category
- Create an entry in /example-events/[category] and gather events such as dodge, miss etc.
- Create enemy avoid sound file /assets/sounds/[language]/[category]/enemy_avoid/[spellName].mp3
- Create self avoid sound file /assets/sounds/[language]/[category]/self_avoid/[spellName].mp3
- Add enemy avoid sound test /test/PVPW_TestSoundEnemyAvoid[category][language].lua
- Add self avoid sound test /test/PVPW_TestSoundSelfAvoid[category][language].lua
- Add enemy avoid combat test /test/PVPW_TestCombatEventsEnemyAvoid[category][language].lua
- Depending on what possible avoids the spell supports different testcases need to be created
- Add self avoid combat test /test/PVPW_TestCombatEventsSelfAvoid[category][language].lua
- Depending on what possible avoids the spell supports different testcases need to be created
- Add tests to /test/PVPW_TestAll[language].lua
Linked spells are spells that have the same name as another spell even though they are different. There are not many spells that match this category. An example is Nature's Swiftness
that can be cast by both a druid and a shaman. The spells are different and have a different spellid. It is however not possible to get the actual spellid from the combatlog of an enemy player. This is a limit by the wow api to better match the classic setting where this was not possible.
PVPWarn solves this problem by linking such spells together as one. This means for the player that it is not possible to have different option settings for spells that are linked together. He cannot have the warning for the druids cast of Nature's Swiftness
active and have the same on deactivated by the shaman. The settings interface is handling this automatically and always updating linked spells as one.
During combat PVPWarn doesn't really care which spell is used. It will simply take the first one that is found and work from there. This requires that the spells are treated the same and thus essentially are the same. They need to have the same trackedEvents, the same icon, the same soundfile and so on. The only thing that differs between them is their links that point to each other. The only reason the spell has to have an entry in both categories is to show up in the configuration ui.
To check if we as a player avoided an attack/spell we filter for hostile player combat log entries.
if CombatLog_Object_IsA(sourceFlags, COMBATLOG_FILTER_HOSTILE_PLAYERS) then
-- work
end
Example event for a resisted spell. This is from our view and we resisted the counterspell from an enemy player.
{
["spellName"] = "Counterspell",
["target"] = "Player-uid",
["targetName"] = "Targetname",
["event"] = "SPELL_MISSED",
["sourceFlags"] = 66888,
}
For checking if an enemy avoided something from us we need to make sure to include COMBATLOG_FILTER_MINE
. This filters for our own events.
if CombatLog_Object_IsA(sourceFlags, COMBATLOG_FILTER_MINE) then
-- work
end
Example event for a resisted spell. In this case counterspell was casted and the enemy (the targetname) resisted the spell.
{
["spellName"] = "Counterspell",
["target"] = "Player-uid",
["targetName"] = "Targetname",
["event"] = "SPELL_MISSED",
["sourceFlags"] = 1297,
}
The name spell missed might be a bit misleading. It is important to know that even physical spells are considered spells and thus the event SPELL_MISSED
is used for everything that is related to avoiding a spell in some way. WoW supports the following misstypes.
- ABSORB
- BLOCK
- DEFLECT
- DODGE
- EVADE
- IMMUNE
- MISS
- PARRY
- REFLECT
- RESIST
- DODGE
- PARRY
- IMMUNE
- MISS
- BLOCK
- RESIST
PVPWarn uses the exact missType for two things.
PVPWarn filters unwanted missTypes. See above for supported missTypes. As an example completely absorbing a spell such as Cone of Cold
with a Power Word: Shield
is in the eyes of PVPWarn not an avoid. By filtering ABSORB
those events will not be processed.
Certain spells might not support a specific misstype. The spellAvoidMap has the ultimate control in what PVPWarn thinks what possible avoids each spell has. Before an avoid event is announced the spellAvoidMap has to be consulted about whether the spell supports that misstype event.