Skip to content

Commit

Permalink
Add in remaining hotfixes for the upcoming Tuesday. REVERT ONCE SPELL…
Browse files Browse the repository at this point in the history
…DATA IS AVAILABLE.
  • Loading branch information
Collisionc committed Jan 15, 2017
1 parent 22e20c6 commit a3b6586
Show file tree
Hide file tree
Showing 8 changed files with 135 additions and 24 deletions.
2 changes: 2 additions & 0 deletions engine/class_modules/sc_death_knight.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
// ==========================================================================

// TODO:
// - UPDATE SPELLS BASED ON HOTFIXES JANUARY 17th. TEMPORARY //FIXME ADDED FOR NOW
// Unholy
// - Does Festering Wound (generation|consumption) require a positive hit result?
// - Festering Strike Festering Wound generation probability distribution
Expand Down Expand Up @@ -3680,6 +3681,7 @@ struct blooddrinker_t : public death_knight_spell_t

channeled = true;
base_tick_time = timespan_t::from_seconds( 1.0 );
base_multiplier *= 0.6; //FIXME Jan 17th Hotfix
}

void tick( dot_t* d ) override
Expand Down
82 changes: 70 additions & 12 deletions engine/class_modules/sc_hunter.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
// TODO
// General
// - Cleanup old spells
//
// - UPDATE SPELLS BASED ON HOTFIXES JANUARY 17th. TEMPORARY //FIXME ADDED FOR NOW
// Survival
// - Harpoon legendary
//
Expand Down Expand Up @@ -1969,6 +1969,9 @@ struct kill_command_t: public hunter_pet_action_t < hunter_pet_t, attack_t >

if ( o() -> artifacts.jaws_of_thunder.rank() )
jaws_of_thunder = new jaws_of_thunder_t( p );

if ( player -> specialization() == HUNTER_BEAST_MASTERY )
base_multiplier *= 1.10; //FIXME Jan 17th Hotfix
}

virtual void impact( action_state_t* s ) override
Expand Down Expand Up @@ -2210,6 +2213,9 @@ struct flanking_strike_t: public hunter_main_pet_attack_t
if ( p -> o() -> sets.has_set_bonus( HUNTER_SURVIVAL, T19, B2 ) )
hunting_companion_multiplier *= p -> o() -> sets.set( HUNTER_SURVIVAL, T19, B2 ) -> effectN( 1 ).base_value();

if ( p -> specialization() == HUNTER_SURVIVAL )
base_multiplier *= 1.07; //FIXME

if ( p -> o() -> talents.aspect_of_the_beast -> ok() )
{
impact_action = new bestial_ferocity_t( p );
Expand Down Expand Up @@ -2462,6 +2468,9 @@ struct volley_tick_t: hunter_ranged_attack_t

if ( data().affected_by( p -> specs.beast_mastery_hunter -> effectN( 6 ) ) )
base_multiplier *= 1.0 + p -> specs.beast_mastery_hunter -> effectN( 6 ).percent();

if ( p -> specialization() == HUNTER_MARKSMANSHIP )
base_multiplier *= 1.08; //FIXME
}

virtual void execute() override
Expand Down Expand Up @@ -2682,12 +2691,12 @@ struct barrage_t: public hunter_ranged_attack_t
range = radius;
range = 0;
travel_speed = 0.0;
}

void impact(action_state_t* s) override {
// Simulate the random chance of hitting for secondary targets.
if (rng().roll(0.5))
hunter_ranged_attack_t::impact(s);
if ( data().affected_by( player -> specs.beast_mastery_hunter -> effectN( 5 ) ) )
base_multiplier *= 1.0 + player -> specs.beast_mastery_hunter -> effectN( 5 ).percent();
if ( player -> specialization() == HUNTER_BEAST_MASTERY )
base_multiplier *= 1.10; //FIXME Jan 17th Hotfix
else if ( player -> specialization() == HUNTER_MARKSMANSHIP )
base_multiplier *= 1.08; //FIXME
}
};

Expand All @@ -2707,9 +2716,6 @@ struct barrage_t: public hunter_ranged_attack_t
tick_action = new barrage_damage_t( player );

starved_proc = player -> get_proc( "starved: barrage" );

if ( data().affected_by( player -> specs.beast_mastery_hunter -> effectN( 5 ) ) )
base_multiplier *= 1.0 + player -> specs.beast_mastery_hunter -> effectN( 5 ).percent();
}

void schedule_execute( action_state_t* state = nullptr ) override
Expand All @@ -2734,6 +2740,9 @@ struct multi_shot_t: public hunter_ranged_attack_t
may_proc_bullseye = false;
aoe = -1;

if ( p -> specialization() == HUNTER_MARKSMANSHIP )
base_multiplier *= 1.08; //FIXME

if ( p -> artifacts.called_shot.rank() )
base_multiplier *= 1.0 + p -> artifacts.called_shot.percent();

Expand Down Expand Up @@ -2863,6 +2872,8 @@ struct chimaera_shot_impact_t: public hunter_ranged_attack_t
energize_type = ENERGIZE_PER_HIT;
energize_resource = RESOURCE_FOCUS;
energize_amount = p -> find_spell( 204304 ) -> effectN( 1 ).resource( RESOURCE_FOCUS );
if ( player -> specialization() == HUNTER_BEAST_MASTERY )
base_multiplier *= 1.10; //FIXME Jan 17th Hotfix
}
};

Expand Down Expand Up @@ -2900,11 +2911,12 @@ struct chimaera_shot_t: public hunter_ranged_attack_t

struct cobra_shot_t: public hunter_ranged_attack_t
{

cobra_shot_t( hunter_t* player, const std::string& options_str ):
hunter_ranged_attack_t( "cobra_shot", player, player -> find_specialization_spell( "Cobra Shot" ) )
{
parse_options( options_str );
if ( player -> specialization() == HUNTER_BEAST_MASTERY )
base_multiplier *= 1.46; //FIXME Jan 17th Hotfix
}

virtual void execute() override
Expand Down Expand Up @@ -2983,6 +2995,8 @@ struct black_arrow_t: public hunter_ranged_attack_t
tick_may_crit = true;
hasted_ticks = false;
duration = this -> dot_duration;
if ( player -> specialization() == HUNTER_MARKSMANSHIP )
base_multiplier *= 1.08; //FIXME
}

virtual void execute() override
Expand All @@ -3004,6 +3018,8 @@ struct bursting_shot_t : public hunter_ranged_attack_t
hunter_ranged_attack_t( "bursting_shot", player, player -> find_spell( 186387 ) )
{
parse_options( options_str );
if ( player -> specialization() == HUNTER_MARKSMANSHIP )
base_multiplier *= 1.08; //FIXME
}

void init() override
Expand Down Expand Up @@ -3183,6 +3199,8 @@ struct aimed_shot_t: public aimed_shot_base_t
legacy_of_the_windrunners = new legacy_of_the_windrunners_t( p );
add_child( legacy_of_the_windrunners );
}
if ( p -> specialization() == HUNTER_MARKSMANSHIP )
base_multiplier *= 1.08; //FIXME
}

virtual double cost() const override
Expand Down Expand Up @@ -3270,6 +3288,8 @@ struct arcane_shot_t: public hunter_ranged_attack_t
energize_type = ENERGIZE_ON_HIT;
energize_resource = RESOURCE_FOCUS;
energize_amount = p -> find_spell( 187675 ) -> effectN( 1 ).base_value();
if ( p -> specialization() == HUNTER_MARKSMANSHIP )
base_multiplier *= 1.08; //FIXME
}

void try_steady_focus() override
Expand Down Expand Up @@ -3352,6 +3372,8 @@ struct marked_shot_t: public hunter_spell_t

if ( p -> artifacts.windrunners_guidance.rank() )
base_multiplier *= 1.0 + p -> artifacts.windrunners_guidance.percent();
if ( p -> specialization() == HUNTER_MARKSMANSHIP )
base_multiplier *= 1.08; //FIXME
}

void execute() override
Expand Down Expand Up @@ -3500,6 +3522,8 @@ struct piercing_shot_t: public hunter_ranged_attack_t
// Spell data is currently bugged on alpha
base_multiplier = 2.0;
base_aoe_multiplier = 0.5;
if ( p -> specialization() == HUNTER_MARKSMANSHIP )
base_multiplier *= 1.08; //FIXME
}

virtual void execute() override
Expand Down Expand Up @@ -3593,6 +3617,9 @@ struct sidewinders_t: hunter_ranged_attack_t

if ( p -> artifacts.called_shot.rank() )
base_multiplier *= 1.0 + p -> artifacts.called_shot.percent();

if ( p -> specialization() == HUNTER_MARKSMANSHIP )
base_multiplier *= 1.08; //FIXME
}

virtual void execute() override
Expand Down Expand Up @@ -3644,6 +3671,8 @@ struct windburst_t: hunter_ranged_attack_t
hunter_ranged_attack_t( "windburst", p, &p -> artifacts.windburst.data() )
{
parse_options( options_str );
if ( p -> specialization() == HUNTER_MARKSMANSHIP )
base_multiplier *= 1.08; //FIXME
}

void impact(action_state_t* s) override
Expand Down Expand Up @@ -3788,6 +3817,8 @@ struct mongoose_bite_t: hunter_melee_attack_t
{
parse_options( options_str );
cooldown -> hasted = true; // not in spell data for some reason
if ( p -> specialization() == HUNTER_SURVIVAL )
base_multiplier *= 1.07; //FIXME
}

virtual void execute() override
Expand Down Expand Up @@ -3834,6 +3865,8 @@ struct flanking_strike_t: hunter_melee_attack_t
hunter_melee_attack_t( "flanking_strike", p, p -> specs.flanking_strike )
{
parse_options( options_str );
if ( p -> specialization() == HUNTER_SURVIVAL )
base_multiplier *= 1.07; //FIXME
}

virtual void execute() override
Expand Down Expand Up @@ -3910,6 +3943,9 @@ struct lacerate_t: public hunter_melee_attack_t
weapon_multiplier = 0.0;
weapon_power_mod = 0.0;

if ( p -> specialization() == HUNTER_SURVIVAL )
base_multiplier *= 1.12; //FIXME

if ( p -> artifacts.lacerating_talons.rank() )
base_multiplier *= 1.0 + p -> artifacts.lacerating_talons.percent();
}
Expand Down Expand Up @@ -3947,6 +3983,8 @@ struct serpent_sting_t: public hunter_melee_attack_t
tick_may_crit = true;
hasted_ticks = false;
weapon_multiplier = 0;
if ( player -> specialization() == HUNTER_SURVIVAL )
base_multiplier *= 1.12; //FIXME
}
};

Expand All @@ -3965,6 +4003,8 @@ struct carve_t: public hunter_melee_attack_t

if ( p -> talents.serpent_sting -> ok() )
impact_action = new serpent_sting_t( p );
if ( p -> specialization() == HUNTER_SURVIVAL )
base_multiplier *= 1.07; //FIXME
}

virtual void execute() override
Expand Down Expand Up @@ -4190,7 +4230,8 @@ struct raptor_strike_t: public hunter_melee_attack_t
hunter_melee_attack_t( "raptor_strike", p, p -> specs.raptor_strike )
{
parse_options( options_str );

if ( p -> specialization() == HUNTER_SURVIVAL )
base_multiplier *= 1.07; //FIXME
if ( p -> talents.serpent_sting -> ok() )
impact_action = new serpent_sting_t( p );
}
Expand Down Expand Up @@ -4305,6 +4346,8 @@ struct peck_t : public hunter_spell_t
may_block = false;
may_dodge = false;
travel_speed = 0.0;
if ( player -> specialization() == HUNTER_MARKSMANSHIP )
base_multiplier *= 1.08; //FIXME
}

hunter_t* p() const { return static_cast<hunter_t*>( player ); }
Expand Down Expand Up @@ -5079,6 +5122,18 @@ struct explosive_trap_t: public hunter_spell_t
base_multiplier *= 1.0 + p -> talents.guerrilla_tactics -> effectN( 7 ).percent();
}

void init() override
{
hunter_spell_t::init();

if ( p() -> specialization() == HUNTER_SURVIVAL )
{
base_dd_multiplier *= 1.07; //FIXME
base_td_multiplier *= 1.12;
}

}

virtual double action_multiplier() const override
{
double am = hunter_spell_t::action_multiplier();
Expand Down Expand Up @@ -5183,6 +5238,9 @@ struct caltrops_t: public hunter_spell_t

if ( p -> artifacts.hunters_guile.rank() )
cooldown -> duration *= 1.0 + p -> artifacts.hunters_guile.percent();

if ( p -> specialization() == HUNTER_SURVIVAL )
base_multiplier *= 0.9; //FIXME
}
};

Expand Down
3 changes: 3 additions & 0 deletions engine/class_modules/sc_mage.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ namespace { // UNNAMED NAMESPACE

// ==========================================================================
// Mage
// - UPDATE SPELLS BASED ON HOTFIXES JANUARY 17th. TEMPORARY //FIXME ADDED FOR NOW
// ==========================================================================

// Forward declarations
Expand Down Expand Up @@ -4099,6 +4100,7 @@ struct flame_patch_t : public fire_mage_spell_t
school = SCHOOL_FIRE;
// PTR Multiplier
base_multiplier *= 1.0 + p -> find_spell( 137019 ) -> effectN( 1 ).percent();
base_multiplier *= 0.83; //FIXME Jan 17th Hotfix
}

// Override damage type to avoid triggering Doom Nova
Expand Down Expand Up @@ -5910,6 +5912,7 @@ struct ray_of_frost_t : public frost_mage_spell_t

// PTR Multiplier
base_multiplier *= 1.0 + p -> find_spell( 137020 ) -> effectN( 1 ).percent();
base_multiplier *= 0.88; //FIXME Jan 17th Hotfix
}

void init() override
Expand Down
Loading

0 comments on commit a3b6586

Please sign in to comment.