diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/map/script.c | 8 | ||||
-rw-r--r-- | src/map/status.c | 15 |
2 files changed, 19 insertions, 4 deletions
diff --git a/src/map/script.c b/src/map/script.c index dca64002c..3edcbaf92 100644 --- a/src/map/script.c +++ b/src/map/script.c @@ -7204,6 +7204,14 @@ int buildin_getnpctimer(struct script_state *st) nd=npc_name2id(conv_str(st,& (st->stack->stack_data[st->start+3]))); else nd=(struct npc_data *)map_id2bl(st->oid); + + if (!nd || nd->bl.type != BL_NPC) + { + push_val(st->stack,C_INT,0); + if (battle_config.error_log) + ShowError("getnpctimer: Invalid NPC\n"); + return 1; + } switch(type){ case 0: val=npc_gettimerevent_tick(nd); break; diff --git a/src/map/status.c b/src/map/status.c index aee10e721..dab6861ea 100644 --- a/src/map/status.c +++ b/src/map/status.c @@ -4931,18 +4931,25 @@ int status_change_start(struct block_list *bl,int type,int rate,int val1,int val case SC_STRIPWEAPON: if (sd) { int i; + opt_flag = 0; //Reuse to check success condition. if(sd->unstripable_equip&EQP_WEAPON) return 0; i = sd->equip_index[EQI_HAND_L]; if (i>=0 && sd->inventory_data[i] && sd->inventory_data[i]->type == IT_WEAPON) + { + opt_flag|=1; pc_unequipitem(sd,i,3); //L-hand weapon + } i = sd->equip_index[EQI_HAND_R]; - if (i<0 || !sd->inventory_data[i] || - sd->inventory_data[i]->type != IT_WEAPON) - return 0; - pc_unequipitem(sd,i,3); + if (i>=0 && sd->inventory_data[i] && + sd->inventory_data[i]->type == IT_WEAPON) + { + opt_flag|=2; + pc_unequipitem(sd,i,3); + } + if (!opt_flag) return 0; } else //Watk reduction val2 = 5*val1; break; |