summaryrefslogtreecommitdiff
path: root/src/map
diff options
context:
space:
mode:
Diffstat (limited to 'src/map')
-rw-r--r--src/map/pc.c13
-rw-r--r--src/map/status.c3
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;