+ p_ptr->update |= (PU_MON_LITE);
+ }
+
+ y = m_ptr->fy;
+ x = m_ptr->fx;
+
+ if (record_named_pet && is_pet(m_ptr) && m_ptr->nickname)
+ {
+ GAME_TEXT m_name[MAX_NLEN];
+
+ monster_desc(m_name, m_ptr, MD_INDEF_VISIBLE);
+ exe_write_diary(p_ptr, NIKKI_NAMED_PET, 3, m_name);
+ }
+
+ /* Let monsters explode! */
+ for (i = 0; i < 4; i++)
+ {
+ if (r_ptr->blow[i].method == RBM_EXPLODE)
+ {
+ BIT_FLAGS flg = PROJECT_GRID | PROJECT_ITEM | PROJECT_KILL;
+ EFFECT_ID typ = mbe_info[r_ptr->blow[i].effect].explode_type;
+ DICE_NUMBER d_dice = r_ptr->blow[i].d_dice;
+ DICE_SID d_side = r_ptr->blow[i].d_side;
+ HIT_POINT damage = damroll(d_dice, d_side);
+
+ project(m_idx, 3, y, x, damage, typ, flg, -1);
+ break;
+ }
+ }
+
+ if (m_ptr->mflag2 & MFLAG2_CHAMELEON)
+ {
+ choose_new_monster(m_idx, TRUE, MON_CHAMELEON);
+ r_ptr = &r_info[m_ptr->r_idx];
+ }
+
+ check_quest_completion(m_ptr);
+
+ /* Handle the possibility of player vanquishing arena combatant -KMW- */
+ if (p_ptr->inside_arena && !is_pet(m_ptr))
+ {
+ p_ptr->exit_bldg = TRUE;
+
+ if (p_ptr->arena_number > MAX_ARENA_MONS)
+ {
+ msg_print(_("素晴らしい!君こそ真の勝利者だ。", "You are a Genuine Champion!"));
+ }
+ else
+ {
+ msg_print(_("勝利!チャンピオンへの道を進んでいる。", "Victorious! You're on your way to becoming Champion."));
+ }
+
+ if (arena_info[p_ptr->arena_number].tval)
+ {
+ q_ptr = &forge;
+
+ /* Prepare to make a prize */
+ object_prep(q_ptr, lookup_kind(arena_info[p_ptr->arena_number].tval, arena_info[p_ptr->arena_number].sval));
+ apply_magic(q_ptr, current_floor_ptr->object_level, AM_NO_FIXED_ART);
+ (void)drop_near(q_ptr, -1, y, x);
+ }
+
+ if (p_ptr->arena_number > MAX_ARENA_MONS) p_ptr->arena_number++;
+ p_ptr->arena_number++;
+ if (record_arena)
+ {
+ GAME_TEXT m_name[MAX_NLEN];
+
+ monster_desc(m_name, m_ptr, MD_WRONGDOER_NAME);
+
+ exe_write_diary(p_ptr, NIKKI_ARENA, p_ptr->arena_number, m_name);
+ }
+ }
+
+ if (m_idx == p_ptr->riding)
+ {
+ if (rakuba(-1, FALSE))
+ {
+ msg_print(_("地面に落とされた。", "You have fallen from your riding pet."));
+ }
+ }
+
+ /* Drop a dead corpse? */
+ if (one_in_(r_ptr->flags1 & RF1_UNIQUE ? 1 : 4) &&
+ (r_ptr->flags9 & (RF9_DROP_CORPSE | RF9_DROP_SKELETON)) &&
+ !(p_ptr->inside_arena || p_ptr->phase_out || cloned || ((m_ptr->r_idx == today_mon) && is_pet(m_ptr))))
+ {
+ /* Assume skeleton */
+ bool corpse = FALSE;
+
+ /*
+ * We cannot drop a skeleton? Note, if we are in this check,
+ * we *know* we can drop at least a corpse or a skeleton
+ */
+ if (!(r_ptr->flags9 & RF9_DROP_SKELETON))
+ corpse = TRUE;
+ else if ((r_ptr->flags9 & RF9_DROP_CORPSE) && (r_ptr->flags1 & RF1_UNIQUE))
+ corpse = TRUE;
+
+ /* Else, a corpse is more likely unless we did a "lot" of damage */
+ else if (r_ptr->flags9 & RF9_DROP_CORPSE)
+ {
+ /* Lots of damage in one blow */
+ if ((0 - ((m_ptr->maxhp) / 4)) > m_ptr->hp)
+ {
+ if (one_in_(5)) corpse = TRUE;
+ }
+ else
+ {
+ if (!one_in_(5)) corpse = TRUE;
+ }
+ }
+ q_ptr = &forge;
+
+ /* Prepare to make an object */
+ object_prep(q_ptr, lookup_kind(TV_CORPSE, (corpse ? SV_CORPSE : SV_SKELETON)));
+
+ apply_magic(q_ptr, current_floor_ptr->object_level, AM_NO_FIXED_ART);
+
+ q_ptr->pval = m_ptr->r_idx;
+ (void)drop_near(q_ptr, -1, y, x);
+ }
+
+ /* Drop objects being carried */
+ monster_drop_carried_objects(m_ptr);
+
+ if (r_ptr->flags1 & RF1_DROP_GOOD) mo_mode |= AM_GOOD;
+ if (r_ptr->flags1 & RF1_DROP_GREAT) mo_mode |= AM_GREAT;
+
+ switch (m_ptr->r_idx)
+ {
+ case MON_PINK_HORROR:
+ /* Pink horrors are replaced with 2 Blue horrors */
+ if (!(p_ptr->inside_arena || p_ptr->phase_out))
+ {
+ bool notice = FALSE;
+
+ for (i = 0; i < 2; i++)
+ {
+ POSITION wy = y, wx = x;
+ bool pet = is_pet(m_ptr);
+ BIT_FLAGS mode = 0L;
+
+ if (pet) mode |= PM_FORCE_PET;
+
+ if (summon_specific((pet ? -1 : m_idx), wy, wx, 100, SUMMON_BLUE_HORROR, mode))
+ {
+ if (player_can_see_bold(wy, wx)) notice = TRUE;
+ }
+ }
+
+ if (notice) msg_print(_("ピンク・ホラーは分裂した!", "The Pink horror divides!"));
+ }
+ break;
+
+ case MON_BLOODLETTER:
+ /* Bloodletters of Khorne may drop a blade of chaos */
+ if (drop_chosen_item && (randint1(100) < 15))
+ {
+ q_ptr = &forge;
+
+ /* Prepare to make a Blade of Chaos */
+ object_prep(q_ptr, lookup_kind(TV_SWORD, SV_BLADE_OF_CHAOS));
+
+ apply_magic(q_ptr, current_floor_ptr->object_level, AM_NO_FIXED_ART | mo_mode);
+ (void)drop_near(q_ptr, -1, y, x);
+ }
+ break;
+
+ case MON_RAAL:
+ if (drop_chosen_item && (current_floor_ptr->dun_level > 9))
+ {
+ q_ptr = &forge;
+ object_wipe(q_ptr);
+
+ /* Activate restriction */
+ if ((current_floor_ptr->dun_level > 49) && one_in_(5))
+ get_obj_num_hook = kind_is_good_book;
+ else
+ get_obj_num_hook = kind_is_book;
+
+ /* Make a book */
+ make_object(q_ptr, mo_mode);
+ (void)drop_near(q_ptr, -1, y, x);
+ }
+ break;
+
+ case MON_DAWN:
+ /*
+ * Mega^3-hack: killing a 'Warrior of the Dawn' is likely to
+ * spawn another in the fallen one's place!
+ */
+ if (!p_ptr->inside_arena && !p_ptr->phase_out)
+ {
+ if (!one_in_(7))
+ {
+ POSITION wy = y, wx = x;
+ int attempts = 100;
+ bool pet = is_pet(m_ptr);
+
+ do
+ {
+ scatter(&wy, &wx, y, x, 20, 0);
+ } while (!(in_bounds(wy, wx) && cave_empty_bold2(wy, wx)) && --attempts);
+
+ if (attempts > 0)
+ {
+ BIT_FLAGS mode = 0L;
+ if (pet) mode |= PM_FORCE_PET;
+
+ if (summon_specific((pet ? -1 : m_idx), wy, wx, 100, SUMMON_DAWN, mode))
+ {
+ if (player_can_see_bold(wy, wx))
+ msg_print(_("新たな戦士が現れた!", "A new warrior steps forth!"));
+ }
+ }
+ }
+ }
+ break;
+
+ case MON_UNMAKER:
+ /* One more ultra-hack: An Unmaker goes out with a big bang! */
+ {
+ BIT_FLAGS flg = PROJECT_GRID | PROJECT_ITEM | PROJECT_KILL;
+ (void)project(m_idx, 6, y, x, 100, GF_CHAOS, flg, -1);
+ }
+ break;
+
+ case MON_UNICORN_ORD:
+ case MON_MORGOTH:
+ case MON_ONE_RING:
+ /* Reward for "lazy" player */
+ if (p_ptr->pseikaku == SEIKAKU_NAMAKE)
+ {
+ ARTIFACT_IDX a_idx = 0;
+ artifact_type *a_ptr = NULL;
+
+ if (!drop_chosen_item) break;
+
+ do
+ {
+ switch (randint0(3))
+ {
+ case 0:
+ a_idx = ART_NAMAKE_HAMMER;
+ break;
+ case 1:
+ a_idx = ART_NAMAKE_BOW;
+ break;
+ case 2:
+ a_idx = ART_NAMAKE_ARMOR;
+ break;
+ }
+
+ a_ptr = &a_info[a_idx];
+ } while (a_ptr->cur_num);
+
+ if (create_named_art(a_idx, y, x))
+ {
+ a_ptr->cur_num = 1;
+
+ /* Hack -- Memorize location of artifact in saved floors */
+ if (current_world_ptr->character_dungeon) a_ptr->floor_id = p_ptr->floor_id;
+ }
+ else if (!preserve_mode) a_ptr->cur_num = 1;
+ }
+ break;
+
+ case MON_SERPENT:
+ if (!drop_chosen_item) break;
+ q_ptr = &forge;
+
+ /* Mega-Hack -- Prepare to make "Grond" */
+ object_prep(q_ptr, lookup_kind(TV_HAFTED, SV_GROND));
+
+ /* Mega-Hack -- Mark this item as "Grond" */
+ q_ptr->name1 = ART_GROND;
+
+ /* Mega-Hack -- Actually create "Grond" */
+ apply_magic(q_ptr, -1, AM_GOOD | AM_GREAT);
+ (void)drop_near(q_ptr, -1, y, x);
+ q_ptr = &forge;
+
+ /* Mega-Hack -- Prepare to make "Chaos" */
+ object_prep(q_ptr, lookup_kind(TV_CROWN, SV_CHAOS));
+
+ /* Mega-Hack -- Mark this item as "Chaos" */
+ q_ptr->name1 = ART_CHAOS;
+
+ /* Mega-Hack -- Actually create "Chaos" */
+ apply_magic(q_ptr, -1, AM_GOOD | AM_GREAT);
+ (void)drop_near(q_ptr, -1, y, x);
+ break;
+
+ case MON_B_DEATH_SWORD:
+ if (drop_chosen_item)
+ {
+ q_ptr = &forge;
+
+ /* Prepare to make a broken sword */
+ object_prep(q_ptr, lookup_kind(TV_SWORD, randint1(2)));
+ (void)drop_near(q_ptr, -1, y, x);
+ }
+ break;
+
+ case MON_A_GOLD:
+ case MON_A_SILVER:
+ if (drop_chosen_item && ((m_ptr->r_idx == MON_A_GOLD) ||
+ ((m_ptr->r_idx == MON_A_SILVER) && (r_ptr->r_akills % 5 == 0))))
+ {
+ q_ptr = &forge;
+
+ /* Prepare to make a Can of Toys */
+ object_prep(q_ptr, lookup_kind(TV_CHEST, SV_CHEST_KANDUME));
+
+ apply_magic(q_ptr, current_floor_ptr->object_level, AM_NO_FIXED_ART);
+ (void)drop_near(q_ptr, -1, y, x);
+ }
+ break;
+
+ case MON_ROLENTO:
+ {
+ BIT_FLAGS flg = PROJECT_GRID | PROJECT_ITEM | PROJECT_KILL;
+ (void)project(m_idx, 3, y, x, damroll(20, 10), GF_FIRE, flg, -1);
+ }
+ break;
+