diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/map/battle.c | 10 | ||||
-rw-r--r-- | src/map/skill.c | 4 | ||||
-rw-r--r-- | src/map/status.c | 1 | ||||
-rw-r--r-- | src/map/status.h | 2 |
4 files changed, 16 insertions, 1 deletions
diff --git a/src/map/battle.c b/src/map/battle.c index cea562661..86297f271 100644 --- a/src/map/battle.c +++ b/src/map/battle.c @@ -542,6 +542,16 @@ int battle_calc_damage(struct block_list *src,struct block_list *bl,struct Damag status_change_end(bl, SC_AETERNA, INVALID_TIMER); //Shouldn't end until Breaker's non-weapon part connects. } +#ifdef RENEWAL + if( sc->data[SC_RAID] ) + { + damage += 20*damage/100; + + if (--sc->data[SC_RAID]->val1 == 0) + status_change_end(bl, SC_RAID, INVALID_TIMER); + } +#endif + if( damage ) { if( sc->data[SC_DEEPSLEEP] ) { diff --git a/src/map/skill.c b/src/map/skill.c index 252bb4bf1..3000023d3 100644 --- a/src/map/skill.c +++ b/src/map/skill.c @@ -930,6 +930,10 @@ int skill_additional_effect (struct block_list* src, struct block_list *bl, int case RG_RAID: sc_start(bl,SC_STUN,(10+3*skilllv),skilllv,skill_get_time(skillid,skilllv)); sc_start(bl,SC_BLIND,(10+3*skilllv),skilllv,skill_get_time2(skillid,skilllv)); + +#ifdef RENEWAL + sc_start(bl,SC_RAID,100,7,5000); +#endif break; case BA_FROSTJOKER: diff --git a/src/map/status.c b/src/map/status.c index 972553d94..a53a74e14 100644 --- a/src/map/status.c +++ b/src/map/status.c @@ -282,6 +282,7 @@ void initChangeTables(void) set_sc( NPC_HALLUCINATION , SC_HALLUCINATION , SI_HALLUCINATION , SCB_NONE ); add_sc( NPC_REBIRTH , SC_REBIRTH ); add_sc( RG_RAID , SC_STUN ); + add_sc( RG_RAID , SC_RAID ); set_sc( RG_STRIPWEAPON , SC_STRIPWEAPON , SI_STRIPWEAPON , SCB_WATK ); set_sc( RG_STRIPSHIELD , SC_STRIPSHIELD , SI_STRIPSHIELD , SCB_DEF ); set_sc( RG_STRIPARMOR , SC_STRIPARMOR , SI_STRIPARMOR , SCB_VIT ); diff --git a/src/map/status.h b/src/map/status.h index fd4c32319..da9471467 100644 --- a/src/map/status.h +++ b/src/map/status.h @@ -592,7 +592,7 @@ typedef enum sc_type { SC_SOULCOLD, //510 SC_HAWKEYES, SC_ODINS_POWER, - + SC_RAID, SC_MAX, //Automatically updated max, used in for's to check we are within bounds. } sc_type; |