mirror of
https://github.com/mangosfour/server.git
synced 2025-12-14 07:37:01 +00:00
[8082] Update Diminishing Returns.
Signed-off-by: VladimirMangos <vladimir@getmangos.com>
This commit is contained in:
parent
1b085414ab
commit
df064ebd9f
7 changed files with 86 additions and 55 deletions
|
|
@ -2717,36 +2717,32 @@ DiminishingGroup GetDiminishingReturnsGroupForSpell(SpellEntry const* spellproto
|
|||
{
|
||||
case SPELLFAMILY_ROGUE:
|
||||
{
|
||||
// Kidney Shot
|
||||
if (spellproto->SpellFamilyFlags & UI64LIT(0x00000200000))
|
||||
return DIMINISHING_KIDNEYSHOT;
|
||||
// Blind
|
||||
else if (spellproto->SpellFamilyFlags & UI64LIT(0x00001000000))
|
||||
return DIMINISHING_BLIND_CYCLONE;
|
||||
break;
|
||||
}
|
||||
case SPELLFAMILY_HUNTER:
|
||||
{
|
||||
// Freezing trap
|
||||
if (spellproto->SpellFamilyFlags & UI64LIT(0x00000000008))
|
||||
return DIMINISHING_FREEZE;
|
||||
if (spellproto->SpellFamilyFlags & UI64LIT(0x00001000000))
|
||||
return DIMINISHING_FEAR_BLIND;
|
||||
// Cheap Shot
|
||||
else if (spellproto->SpellFamilyFlags & UI64LIT(0x00000000400))
|
||||
return DIMINISHING_CHEAPSHOT_POUNCE;
|
||||
break;
|
||||
}
|
||||
case SPELLFAMILY_WARLOCK:
|
||||
{
|
||||
// Fear
|
||||
if (spellproto->SpellFamilyFlags & UI64LIT(0x40840000000))
|
||||
return DIMINISHING_WARLOCK_FEAR;
|
||||
// Curses/etc
|
||||
else if (spellproto->SpellFamilyFlags & UI64LIT(0x00080000000))
|
||||
if (spellproto->SpellFamilyFlags & UI64LIT(0x00080000000))
|
||||
return DIMINISHING_LIMITONLY;
|
||||
// Seduction
|
||||
else if (spellproto->SpellFamilyFlags & UI64LIT(0x00040000000))
|
||||
return DIMINISHING_CHARM;
|
||||
break;
|
||||
}
|
||||
case SPELLFAMILY_DRUID:
|
||||
{
|
||||
// Cyclone
|
||||
if (spellproto->SpellFamilyFlags & UI64LIT(0x02000000000))
|
||||
return DIMINISHING_BLIND_CYCLONE;
|
||||
return DIMINISHING_CYCLONE;
|
||||
// Pounce
|
||||
else if (spellproto->SpellFamilyFlags & UI64LIT(0x00000020000))
|
||||
return DIMINISHING_CHEAPSHOT_POUNCE;
|
||||
break;
|
||||
}
|
||||
case SPELLFAMILY_WARRIOR:
|
||||
|
|
@ -2756,6 +2752,20 @@ DiminishingGroup GetDiminishingReturnsGroupForSpell(SpellEntry const* spellproto
|
|||
return DIMINISHING_LIMITONLY;
|
||||
break;
|
||||
}
|
||||
case SPELLFAMILY_PALADIN:
|
||||
{
|
||||
// Turn Evil
|
||||
if (spellproto->SpellFamilyFlags & UI64LIT(0x00804000000000))
|
||||
return DIMINISHING_FEAR_BLIND;
|
||||
break;
|
||||
}
|
||||
case SPELLFAMILY_DEATHKNIGHT:
|
||||
{
|
||||
// Hungering Cold (no flags)
|
||||
if (spellproto->SpellIconID == 2797)
|
||||
return DIMINISHING_POLYMORPH_GOUGE_SAP;
|
||||
break;
|
||||
}
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
|
@ -2764,15 +2774,15 @@ DiminishingGroup GetDiminishingReturnsGroupForSpell(SpellEntry const* spellproto
|
|||
uint32 mechanic = GetAllSpellMechanicMask(spellproto);
|
||||
if (mechanic == MECHANIC_NONE) return DIMINISHING_NONE;
|
||||
if (mechanic & (1<<MECHANIC_STUN)) return triggered ? DIMINISHING_TRIGGER_STUN : DIMINISHING_CONTROL_STUN;
|
||||
if (mechanic & (1<<MECHANIC_SLEEP)) return DIMINISHING_SLEEP;
|
||||
if (mechanic & (1<<MECHANIC_POLYMORPH)) return DIMINISHING_POLYMORPH;
|
||||
if (mechanic & (1<<MECHANIC_SLEEP)) return DIMINISHING_FREEZE_SLEEP;
|
||||
if (mechanic & (1<<MECHANIC_POLYMORPH)) return DIMINISHING_POLYMORPH_GOUGE_SAP;
|
||||
if (mechanic & (1<<MECHANIC_ROOT)) return triggered ? DIMINISHING_TRIGGER_ROOT : DIMINISHING_CONTROL_ROOT;
|
||||
if (mechanic & (1<<MECHANIC_FEAR)) return DIMINISHING_FEAR;
|
||||
if (mechanic & (1<<MECHANIC_FEAR)) return DIMINISHING_FEAR_BLIND;
|
||||
if (mechanic & (1<<MECHANIC_CHARM)) return DIMINISHING_CHARM;
|
||||
if (mechanic & (1<<MECHANIC_SILENCE)) return DIMINISHING_SILENCE;
|
||||
if (mechanic & (1<<DIMINISHING_DISARM)) return DIMINISHING_DISARM;
|
||||
if (mechanic & (1<<MECHANIC_FREEZE)) return DIMINISHING_FREEZE;
|
||||
if (mechanic & ((1<<MECHANIC_KNOCKOUT) | (1<<MECHANIC_SAPPED))) return DIMINISHING_KNOCKOUT;
|
||||
if (mechanic & (1<<MECHANIC_FREEZE)) return DIMINISHING_FREEZE_SLEEP;
|
||||
if (mechanic & ((1<<MECHANIC_KNOCKOUT) | (1<<MECHANIC_SAPPED))) return DIMINISHING_POLYMORPH_GOUGE_SAP;
|
||||
if (mechanic & (1<<MECHANIC_BANISH)) return DIMINISHING_BANISH;
|
||||
if (mechanic & (1<<MECHANIC_HORROR)) return DIMINISHING_DEATHCOIL;
|
||||
|
||||
|
|
@ -2780,23 +2790,49 @@ DiminishingGroup GetDiminishingReturnsGroupForSpell(SpellEntry const* spellproto
|
|||
return DIMINISHING_NONE;
|
||||
}
|
||||
|
||||
int32 GetDiminishingReturnsLimitDuration(DiminishingGroup group, SpellEntry const* spellproto)
|
||||
{
|
||||
if(!IsDiminishingReturnsGroupDurationLimited(group))
|
||||
return 0;
|
||||
|
||||
// Explicit diminishing duration
|
||||
switch(spellproto->SpellFamilyName)
|
||||
{
|
||||
case SPELLFAMILY_HUNTER:
|
||||
{
|
||||
// Wyvern Sting
|
||||
if (spellproto->SpellFamilyFlags & UI64LIT(0x0000100000000000))
|
||||
return 6000;
|
||||
break;
|
||||
}
|
||||
case SPELLFAMILY_PALADIN:
|
||||
{
|
||||
// Repentance - limit to 6 seconds in PvP
|
||||
if (spellproto->SpellFamilyFlags & UI64LIT(0x00000000004))
|
||||
return 6000;
|
||||
break;
|
||||
}
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
return 10000;
|
||||
}
|
||||
|
||||
bool IsDiminishingReturnsGroupDurationLimited(DiminishingGroup group)
|
||||
{
|
||||
switch(group)
|
||||
{
|
||||
case DIMINISHING_CONTROL_STUN:
|
||||
case DIMINISHING_TRIGGER_STUN:
|
||||
case DIMINISHING_KIDNEYSHOT:
|
||||
case DIMINISHING_SLEEP:
|
||||
case DIMINISHING_CONTROL_ROOT:
|
||||
case DIMINISHING_TRIGGER_ROOT:
|
||||
case DIMINISHING_FEAR:
|
||||
case DIMINISHING_WARLOCK_FEAR:
|
||||
case DIMINISHING_FEAR_BLIND:
|
||||
case DIMINISHING_CHARM:
|
||||
case DIMINISHING_POLYMORPH:
|
||||
case DIMINISHING_FREEZE:
|
||||
case DIMINISHING_KNOCKOUT:
|
||||
case DIMINISHING_BLIND_CYCLONE:
|
||||
case DIMINISHING_POLYMORPH_GOUGE_SAP:
|
||||
case DIMINISHING_CHEAPSHOT_POUNCE:
|
||||
case DIMINISHING_FREEZE_SLEEP:
|
||||
case DIMINISHING_CYCLONE:
|
||||
case DIMINISHING_BANISH:
|
||||
case DIMINISHING_LIMITONLY:
|
||||
return true;
|
||||
|
|
@ -2810,24 +2846,21 @@ DiminishingReturnsType GetDiminishingReturnsGroupType(DiminishingGroup group)
|
|||
{
|
||||
switch(group)
|
||||
{
|
||||
case DIMINISHING_BLIND_CYCLONE:
|
||||
case DIMINISHING_CONTROL_STUN:
|
||||
case DIMINISHING_CYCLONE:
|
||||
case DIMINISHING_TRIGGER_STUN:
|
||||
case DIMINISHING_KIDNEYSHOT:
|
||||
case DIMINISHING_CONTROL_STUN:
|
||||
case DIMINISHING_CHEAPSHOT_POUNCE:
|
||||
return DRTYPE_ALL;
|
||||
case DIMINISHING_SLEEP:
|
||||
case DIMINISHING_CONTROL_ROOT:
|
||||
case DIMINISHING_TRIGGER_ROOT:
|
||||
case DIMINISHING_FEAR:
|
||||
case DIMINISHING_FEAR_BLIND:
|
||||
case DIMINISHING_CHARM:
|
||||
case DIMINISHING_POLYMORPH:
|
||||
case DIMINISHING_POLYMORPH_GOUGE_SAP:
|
||||
case DIMINISHING_SILENCE:
|
||||
case DIMINISHING_DISARM:
|
||||
case DIMINISHING_DEATHCOIL:
|
||||
case DIMINISHING_FREEZE:
|
||||
case DIMINISHING_FREEZE_SLEEP:
|
||||
case DIMINISHING_BANISH:
|
||||
case DIMINISHING_WARLOCK_FEAR:
|
||||
case DIMINISHING_KNOCKOUT:
|
||||
return DRTYPE_PLAYER;
|
||||
default:
|
||||
break;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue