diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/map/pc.c | 13 | ||||
-rw-r--r-- | src/map/status.c | 3 |
2 files changed, 13 insertions, 3 deletions
diff --git a/src/map/pc.c b/src/map/pc.c index b73a633d8..6f85aa532 100644 --- a/src/map/pc.c +++ b/src/map/pc.c @@ -6493,6 +6493,19 @@ int pc_dead(struct map_session_data *sd,struct block_list *src) if( (bg = bg_team_search(sd->bg_id)) != NULL && bg->die_event[0] ) npc_event(sd, bg->die_event, 0); } + + // Clear anything NPC-related when you die and was interacting with one. + if (sd->npc_id) + { + if (sd->state.using_fake_npc) + sd->state.using_fake_npc = 0; + if (sd->state.menu_or_input) + sd->state.menu_or_input = 0; + if (sd->npc_menu) + sd->npc_menu = 0; + + npc_event_dequeue(sd); + } npc_script_event(sd,NPCE_DIE); diff --git a/src/map/status.c b/src/map/status.c index 10431bace..9b4a58676 100644 --- a/src/map/status.c +++ b/src/map/status.c @@ -1343,9 +1343,6 @@ int status_damage(struct block_list *src,struct block_list *target,int hp, int s clif_clearunit_area(target,CLR_DEAD); skill_unit_move(target,gettick(),4); skill_cleartimerskill(target); - - if(target->type == BL_PC && ((TBL_PC*)target)->npc_id && flag == 1) - npc_event_dequeue((TBL_PC*)target); } return hp+sp; |