summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorcelest <celest@54d463be-8e91-2dee-dedb-b68131a5f0ec>2005-03-08 11:34:12 +0000
committercelest <celest@54d463be-8e91-2dee-dedb-b68131a5f0ec>2005-03-08 11:34:12 +0000
commitc348cfa676c0cc54f1a1114c1b5654f97163f86c (patch)
tree586531155866a6d6dfadd780b4c88389fbf8e27a /src
parenta274ac2f3b93bca1632d7273503bdbe6d83c9af6 (diff)
downloadhercules-c348cfa676c0cc54f1a1114c1b5654f97163f86c.tar.gz
hercules-c348cfa676c0cc54f1a1114c1b5654f97163f86c.tar.bz2
hercules-c348cfa676c0cc54f1a1114c1b5654f97163f86c.tar.xz
hercules-c348cfa676c0cc54f1a1114c1b5654f97163f86c.zip
Updated Soul Breaker
git-svn-id: https://rathena.svn.sourceforge.net/svnroot/rathena/branches/stable@1214 54d463be-8e91-2dee-dedb-b68131a5f0ec
Diffstat (limited to 'src')
-rw-r--r--src/map/battle.c21
-rw-r--r--src/map/skill.c16
2 files changed, 19 insertions, 18 deletions
diff --git a/src/map/battle.c b/src/map/battle.c
index bffbd0684..f1fdf3efa 100644
--- a/src/map/battle.c
+++ b/src/map/battle.c
@@ -2289,9 +2289,6 @@ static struct Damage battle_calc_pc_weapon_attack(
// calculate physical part of damage
damage = damage * skill_lv;
damage2 = damage2 * skill_lv;
- // calculate magic part of damage
- damage3 = skill_lv * status_get_int(src) * 5;
-
flag=(flag&~BF_RANGEMASK)|BF_LONG;
}
break;
@@ -2558,12 +2555,6 @@ static struct Damage battle_calc_pc_weapon_attack(
//�J�[�h�␳�ɂ�鍶��_���[�W����
//�J�[�h�ɂ��_���[�W��������(����)�����܂�
-// -- moonsoul (cardfix for magic damage portion of ASC_BREAKER)
- if(skill_num == ASC_BREAKER) {
- damage3 = damage3 * cardfix / 100;
- dmg_lv = ATK_DEF; // ignores flee [celest]
- }
-
//�J�[�h�ɂ��_���[�W����������������
if(tsd){ //�Ώۂ�PC�̏ꍇ
cardfix=100;
@@ -2761,14 +2752,6 @@ static struct Damage battle_calc_pc_weapon_attack(
}
}
-
-// -- moonsoul (final combination of phys, mag damage for ASC_BREAKER)
- if(skill_num == ASC_BREAKER) {
- damage3 += rand()%500+500;
- damage += damage3;
-// damage2 += damage3;
- }
-
wd.damage=damage;
wd.damage2=damage2;
wd.type=type;
@@ -3039,6 +3022,10 @@ struct Damage battle_calc_magic_attack(
matk_flag = 0; // don't consider matk and matk2
}
break;
+ case ASC_BREAKER:
+ damage = rand()%500 + 500 + skill_lv * status_get_int(bl) * 5;
+ matk_flag = 0; // don't consider matk and matk2
+ break;
}
}
diff --git a/src/map/skill.c b/src/map/skill.c
index d8ce713c6..0baadbb05 100644
--- a/src/map/skill.c
+++ b/src/map/skill.c
@@ -1236,6 +1236,7 @@ int skill_attack( int attack_type, struct block_list* src, struct block_list *ds
struct Damage dmg;
struct status_change *sc_data;
int type,lv,damage;
+ static int tmpdmg = 0;
if(skillid > 0 && skilllv <= 0) return 0;
@@ -1440,6 +1441,13 @@ int skill_attack( int attack_type, struct block_list* src, struct block_list *ds
case AS_SPLASHER:
clif_skill_damage(dsrc,bl,tick,dmg.amotion,dmg.dmotion, damage, dmg.div_, skillid, -1, 5);
break;
+ case ASC_BREAKER: // [celest]
+ if (attack_type&BF_MAGIC) { // only display damage for the 2nd attack
+ clif_skill_damage(dsrc, bl, tick, dmg.amotion, dmg.dmotion, damage+tmpdmg, dmg.div_, skillid, skilllv, type);
+ tmpdmg = 0; // clear the temporary damage
+ } else
+ tmpdmg = damage; // store the temporary weapon damage
+ break;
case NPC_SELFDESTRUCTION:
case NPC_SELFDESTRUCTION2:
break;
@@ -2156,13 +2164,19 @@ int skill_castend_damage_id( struct block_list* src, struct block_list *bl,int s
// case PA_SACRIFICE: /* �T�N���t�@�C�X */
// case SN_SHARPSHOOTING: /* �V��?�v�V��?�e�B���O */
case CG_ARROWVULCAN: /* �A��?�o���J�� */
- case ASC_BREAKER: /* �\�E���u��?�J? */
+// case ASC_BREAKER: /* �\�E���u��?�J? */
case HW_MAGICCRASHER: /* �}�W�b�N�N���b�V��? */
case ASC_METEORASSAULT: /* ���e�I�A�T���g */
case ITM_TOMAHAWK:
skill_attack(BF_WEAPON,src,src,bl,skillid,skilllv,tick,flag);
break;
+ case ASC_BREAKER: /* �\�E���u��?�J? */ // [DracoRPG]
+ // separate weapon and magic attacks
+ skill_attack(BF_WEAPON,src,src,bl,skillid,skilllv,tick,flag);
+ skill_attack(BF_MAGIC,src,src,bl,skillid,skilllv,tick,flag);
+ break;
+
case SN_SHARPSHOOTING: /* �V��?�v�V��?�e�B���O */
map_foreachinpath (skill_attack_area,src->m, // function, map
src->x,src->y, // source xy