From eb0a137041d3a5ee6385762b8374e98b3867d5a0 Mon Sep 17 00:00:00 2001 From: skotlex Date: Fri, 23 Feb 2007 18:41:56 +0000 Subject: - Minor cleanups - Adjusted menu-based skills so you can't reuse the same skill until you've dealt with the menu. - Adjust autospells so that removing an autospell works when the script of the card that removes the autospell is triggered before the script that adds the spell. - The "requested name of gm-hidden char" warning will not be displayed when the object in question is an NPC (since you can use Intravision to do this). - Corrected the header format for invisible npcs. - Venom Knife no longer takes into accounts cards or EDP. git-svn-id: https://rathena.svn.sourceforge.net/svnroot/rathena/trunk@9905 54d463be-8e91-2dee-dedb-b68131a5f0ec --- src/map/pc.c | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) (limited to 'src/map/pc.c') diff --git a/src/map/pc.c b/src/map/pc.c index 88b7fde40..1dd9fa7f3 100644 --- a/src/map/pc.c +++ b/src/map/pc.c @@ -1193,7 +1193,7 @@ static int pc_bonus_autospell_del(struct s_autospell *spell, int max, short id, if (i<0) return 0; //Nothing to substract from. j = i; - for(; i>=0 && rate > 0; i--) + for(; i>=0 && rate>0; i--) { if (spell[i].id != id || spell[i].lv != lv) continue; if (rate >= spell[i].rate) { @@ -1207,6 +1207,13 @@ static int pc_bonus_autospell_del(struct s_autospell *spell, int max, short id, rate = 0; } } + if (rate > 0 && ++j < max) + { //Tag this as "pending" autospell to remove. + spell[j].id = id; + spell[j].lv = lv; + spell[j].rate = -rate; + spell[j].card_id = 0; + } return rate; } @@ -1216,12 +1223,13 @@ static int pc_bonus_autospell(struct s_autospell *spell, int max, short id, shor pc_bonus_autospell_del(spell, max, id, lv, -rate, card_id); for (i = 0; i < max && spell[i].id; i++) { - if (spell[i].card_id == card_id && + if ((spell[i].card_id == card_id || !spell[i].card_id) && spell[i].id == id && spell[i].lv == lv) { - if (!battle_config.autospell_stacking) + if (!battle_config.autospell_stacking && spell[i].rate > 0) return 0; rate += spell[i].rate; + if (rate < 0) card_id = 0; //Reduced from debted autospell. break; } } -- cgit v1.2.3-70-g09d2