- Fixed flag.elefix not being respected in battle_calc_misc_damage.
- Some code cleanups in battle_calc_damage. git-svn-id: https://svn.code.sf.net/p/rathena/svn/trunk@8139 54d463be-8e91-2dee-dedb-b68131a5f0ec
This commit is contained in:
parent
a7b8adfa3e
commit
f2acf50b24
@ -3,6 +3,9 @@ Date Added
|
|||||||
AS OF SVN REV. 5091, WE ARE NOW USING TRUNK. ALL UNTESTED BUGFIXES/FEATURES GO INTO TRUNK.
|
AS OF SVN REV. 5091, WE ARE NOW USING TRUNK. ALL UNTESTED BUGFIXES/FEATURES GO INTO TRUNK.
|
||||||
IF YOU HAVE A WORKING AND TESTED BUGFIX PUT IT INTO STABLE AS WELL AS TRUNK.
|
IF YOU HAVE A WORKING AND TESTED BUGFIX PUT IT INTO STABLE AS WELL AS TRUNK.
|
||||||
2006/08/04
|
2006/08/04
|
||||||
|
* Fixed flag.elefix not being respected in battle_calc_misc_damage.
|
||||||
|
[Skotlex]
|
||||||
|
* Some code cleanups in battle_calc_damage. [Skotlex]
|
||||||
* Modified bAddItemHealRate so it can receive both item-id and item-group
|
* Modified bAddItemHealRate so it can receive both item-id and item-group
|
||||||
values (since the first item-id is +500, there's no risk of mixing them
|
values (since the first item-id is +500, there's no risk of mixing them
|
||||||
up). [Skotlex]
|
up). [Skotlex]
|
||||||
|
@ -251,12 +251,10 @@ int battle_calc_damage(struct block_list *src,struct block_list *bl,int damage,i
|
|||||||
|
|
||||||
sc = status_get_sc(bl);
|
sc = status_get_sc(bl);
|
||||||
|
|
||||||
if(flag&BF_LONG && map_getcell(bl->m, bl->x, bl->y, CELL_CHKPNEUMA) &&
|
if(flag&(BF_MAGIC|BF_LONG) == BF_LONG &&
|
||||||
((flag&BF_WEAPON && skill_num != NPC_GUIDEDATTACK) ||
|
map_getcell(bl->m, bl->x, bl->y, CELL_CHKPNEUMA) &&
|
||||||
(flag&BF_MISC && skill_num != PA_PRESSURE)
|
skill_num != NPC_GUIDEDATTACK)
|
||||||
)){
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
|
||||||
|
|
||||||
if (sc && sc->count) {
|
if (sc && sc->count) {
|
||||||
//First, sc_*'s that reduce damage to 0.
|
//First, sc_*'s that reduce damage to 0.
|
||||||
@ -340,7 +338,7 @@ int battle_calc_damage(struct block_list *src,struct block_list *bl,int damage,i
|
|||||||
}
|
}
|
||||||
|
|
||||||
//Now damage increasing effects
|
//Now damage increasing effects
|
||||||
if(sc->data[SC_AETERNA].timer!=-1 && skill_num != PA_PRESSURE && skill_num != PF_SOULBURN){
|
if(sc->data[SC_AETERNA].timer!=-1 && skill_num != PF_SOULBURN){
|
||||||
damage<<=1;
|
damage<<=1;
|
||||||
status_change_end( bl,SC_AETERNA,-1 );
|
status_change_end( bl,SC_AETERNA,-1 );
|
||||||
}
|
}
|
||||||
@ -2699,7 +2697,8 @@ struct Damage battle_calc_misc_attack(
|
|||||||
if(md.damage && flag.cardfix && tsd){
|
if(md.damage && flag.cardfix && tsd){
|
||||||
int cardfix = 10000;
|
int cardfix = 10000;
|
||||||
int race2 = status_get_race2(src);
|
int race2 = status_get_race2(src);
|
||||||
cardfix=cardfix*(100-tsd->subele[s_ele])/100;
|
if (flag.elefix)
|
||||||
|
cardfix=cardfix*(100-tsd->subele[s_ele])/100;
|
||||||
cardfix=cardfix*(100-tsd->subsize[sstatus->size])/100;
|
cardfix=cardfix*(100-tsd->subsize[sstatus->size])/100;
|
||||||
cardfix=cardfix*(100-tsd->subrace2[race2])/100;
|
cardfix=cardfix*(100-tsd->subrace2[race2])/100;
|
||||||
cardfix=cardfix*(100-tsd->subrace[sstatus->race])/100;
|
cardfix=cardfix*(100-tsd->subrace[sstatus->race])/100;
|
||||||
@ -2724,8 +2723,9 @@ struct Damage battle_calc_misc_attack(
|
|||||||
md.damage = 0;
|
md.damage = 0;
|
||||||
else if(md.damage && tstatus->mode&MD_PLANT && skill_num != PA_PRESSURE && skill_num != NJ_ZENYNAGE) //Pressure can vaporize plants. // damage=1 on plant with Throw zeny ?
|
else if(md.damage && tstatus->mode&MD_PLANT && skill_num != PA_PRESSURE && skill_num != NJ_ZENYNAGE) //Pressure can vaporize plants. // damage=1 on plant with Throw zeny ?
|
||||||
md.damage = 1;
|
md.damage = 1;
|
||||||
|
|
||||||
md.damage=battle_attr_fix(src, target, md.damage, s_ele, tstatus->def_ele, tstatus->ele_lv);
|
if(flag.elefix)
|
||||||
|
md.damage=battle_attr_fix(src, target, md.damage, s_ele, tstatus->def_ele, tstatus->ele_lv);
|
||||||
|
|
||||||
md.damage=battle_calc_damage(src,target,md.damage,md.div_,skill_num,skill_lv,md.flag);
|
md.damage=battle_calc_damage(src,target,md.damage,md.div_,skill_num,skill_lv,md.flag);
|
||||||
if (map_flag_gvg(target->m))
|
if (map_flag_gvg(target->m))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user