summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/map/battle.c13
-rw-r--r--src/map/skill.c12
2 files changed, 22 insertions, 3 deletions
diff --git a/src/map/battle.c b/src/map/battle.c
index efcf199aa..6cf116db4 100644
--- a/src/map/battle.c
+++ b/src/map/battle.c
@@ -386,10 +386,23 @@ int battle_calc_damage(struct block_list *src,struct block_list *bl,struct Damag
{
struct skill_unit_group* group = skill_id2group(sc->data[SC_SAFETYWALL]->val3);
if (group) {
+ /**
+ * in RE, SW possesses a lifetime equal to 3 times the caster's health
+ **/
+ #if REMODE
+ if ( ( group->val2 - damage) > 0 ) {
+ group->val2 -= damage;
+ d->dmg_lv = ATK_BLOCK;
+ return 0;
+ } else
+ damage -= group->val2;
+ skill_delunitgroup(group);
+ #else
if (--group->val2<=0)
skill_delunitgroup(group);
d->dmg_lv = ATK_BLOCK;
return 0;
+ #endif
}
status_change_end(bl, SC_SAFETYWALL, INVALID_TIMER);
}
diff --git a/src/map/skill.c b/src/map/skill.c
index 3179853c2..5b931e99f 100644
--- a/src/map/skill.c
+++ b/src/map/skill.c
@@ -8850,10 +8850,16 @@ struct skill_unit_group* skill_unitsetting (struct block_list *src, short skilli
status = status_get_status_data(src);
sc = status_get_sc(src); // for traps, firewall and fogwall - celest
- switch( skillid )
- {
+ switch( skillid ) {
case MG_SAFETYWALL:
- val2=skilllv+1;
+ #if REMODE
+ /**
+ * According to data provided in RE, SW life is equal to 3 times caster's health
+ **/
+ val2 = status_get_max_hp(src) * 3;
+ #else
+ val2 = skilllv+1;
+ #endif
break;
case MG_FIREWALL:
if(sc && sc->data[SC_VIOLENTGALE])