OSDN Git Service

レベル15以上のハーフトロル狂戦士も戦士同様に遅消化が得られるのに, 'C'
[hengband/hengband.git] / src / cmd1.c
index 67718ce..f16b037 100644 (file)
@@ -1074,8 +1074,8 @@ static void hit_trap(bool break_trap)
 
        /* Get the cave grid */
        cave_type *c_ptr = &cave[y][x];
-
-       int trap_feat = c_ptr->feat;
+       feature_type *f_ptr = &f_info[c_ptr->feat];
+       int trap_feat_type = have_flag(f_ptr->flags, FF_TRAP) ? f_ptr->subtype : NOT_TRAP;
 
 #ifdef JP
        cptr name = "¥È¥é¥Ã¥×";
@@ -1089,14 +1089,14 @@ static void hit_trap(bool break_trap)
        cave_alter_feat(y, x, FF_HIT_TRAP);
 
        /* Analyze XXX XXX XXX */
-       switch (trap_feat)
+       switch (trap_feat_type)
        {
-               case FEAT_TRAP_TRAPDOOR:
+               case TRAP_TRAPDOOR:
                {
                        if (p_ptr->levitation)
                        {
 #ifdef JP
-                               msg_print("Í¸Í¤òÈô¤Ó±Û¤¨¤¿¡£");
+                               msg_print("Íî¤Ȥ·¸Í¤òÈô¤Ó±Û¤¨¤¿¡£");
 #else
                                msg_print("You fly over a trap door.");
 #endif
@@ -1105,7 +1105,7 @@ static void hit_trap(bool break_trap)
                        else
                        {
 #ifdef JP
-                               msg_print("Í¸Í¤ËÍî¤Á¤¿¡ª");
+                               msg_print("Íî¤Ȥ·¸Í¤ËÍî¤Á¤¿¡ª");
                                if ((p_ptr->pseikaku == SEIKAKU_COMBAT) || (inventory[INVEN_BOW].name1 == ART_CRIMSON))
                                        msg_print("¤¯¤Ã¤½¡Á¡ª");
 #else
@@ -1115,7 +1115,7 @@ static void hit_trap(bool break_trap)
                                sound(SOUND_FALL);
                                dam = damroll(2, 8);
 #ifdef JP
-                               name = "Í¸Í";
+                               name = "Íî¤Ȥ·¸Í";
 #else
                                name = "a trap door";
 #endif
@@ -1127,7 +1127,7 @@ static void hit_trap(bool break_trap)
                                        do_cmd_save_game(TRUE);
 
 #ifdef JP
-                               do_cmd_write_nikki(NIKKI_BUNSHOU, 0, "Í¸Í¤ËÍî¤Á¤¿");
+                               do_cmd_write_nikki(NIKKI_BUNSHOU, 0, "Íî¤Ȥ·¸Í¤ËÍî¤Á¤¿");
 #else
                                do_cmd_write_nikki(NIKKI_BUNSHOU, 0, "You have fallen through a trap door!");
 #endif
@@ -1139,12 +1139,12 @@ static void hit_trap(bool break_trap)
                        break;
                }
 
-               case FEAT_TRAP_PIT:
+               case TRAP_PIT:
                {
                        if (p_ptr->levitation)
                        {
 #ifdef JP
-                               msg_print("Í·ê¤òÈô¤Ó±Û¤¨¤¿¡£");
+                               msg_print("Íî¤Ȥ··ê¤òÈô¤Ó±Û¤¨¤¿¡£");
 #else
                                msg_print("You fly over a pit trap.");
 #endif
@@ -1153,14 +1153,14 @@ static void hit_trap(bool break_trap)
                        else
                        {
 #ifdef JP
-                               msg_print("Í·ê¤ËÍî¤Á¤Æ¤·¤Þ¤Ã¤¿¡ª");
+                               msg_print("Íî¤Ȥ··ê¤ËÍî¤Á¤Æ¤·¤Þ¤Ã¤¿¡ª");
 #else
                                msg_print("You have fallen into a pit!");
 #endif
 
                                dam = damroll(2, 6);
 #ifdef JP
-                               name = "Í·ê";
+                               name = "Íî¤Ȥ··ê";
 #else
                                name = "a pit trap";
 #endif
@@ -1170,12 +1170,12 @@ static void hit_trap(bool break_trap)
                        break;
                }
 
-               case FEAT_TRAP_SPIKED_PIT:
+               case TRAP_SPIKED_PIT:
                {
                        if (p_ptr->levitation)
                        {
 #ifdef JP
-                               msg_print("¥È¥²¤Î¤¢¤ëÍ·ê¤òÈô¤Ó±Û¤¨¤¿¡£");
+                               msg_print("¥È¥²¤Î¤¢¤ëÍî¤Ȥ··ê¤òÈô¤Ó±Û¤¨¤¿¡£");
 #else
                                msg_print("You fly over a spiked pit.");
 #endif
@@ -1184,7 +1184,7 @@ static void hit_trap(bool break_trap)
                        else
                        {
 #ifdef JP
-                       msg_print("¥¹¥Ñ¥¤¥¯¤¬Éߤ«¤ì¤¿Í·ê¤ËÍî¤Á¤Æ¤·¤Þ¤Ã¤¿¡ª");
+                               msg_print("¥¹¥Ñ¥¤¥¯¤¬Éߤ«¤ì¤¿Íî¤È¤··ê¤ËÍî¤Á¤Æ¤·¤Þ¤Ã¤¿¡ª");
 #else
                                msg_print("You fall into a spiked pit!");
 #endif
@@ -1192,7 +1192,7 @@ static void hit_trap(bool break_trap)
 
                                /* Base damage */
 #ifdef JP
-                               name = "Í·ê";
+                               name = "Íî¤Ȥ··ê";
 #else
                                name = "a pit trap";
 #endif
@@ -1210,7 +1210,7 @@ static void hit_trap(bool break_trap)
 
 
 #ifdef JP
-                                       name = "¥È¥²¤Î¤¢¤ëÍ·ê";
+                                       name = "¥È¥²¤Î¤¢¤ëÍî¤Ȥ··ê";
 #else
                                        name = "a spiked pit";
 #endif
@@ -1225,12 +1225,12 @@ static void hit_trap(bool break_trap)
                        break;
                }
 
-               case FEAT_TRAP_POISON_PIT:
+               case TRAP_POISON_PIT:
                {
                        if (p_ptr->levitation)
                        {
 #ifdef JP
-                               msg_print("¥È¥²¤Î¤¢¤ëÍ·ê¤òÈô¤Ó±Û¤¨¤¿¡£");
+                               msg_print("¥È¥²¤Î¤¢¤ëÍî¤Ȥ··ê¤òÈô¤Ó±Û¤¨¤¿¡£");
 #else
                                msg_print("You fly over a spiked pit.");
 #endif
@@ -1239,7 +1239,7 @@ static void hit_trap(bool break_trap)
                        else
                        {
 #ifdef JP
-                       msg_print("¥¹¥Ñ¥¤¥¯¤¬Éߤ«¤ì¤¿Í·ê¤ËÍî¤Á¤Æ¤·¤Þ¤Ã¤¿¡ª");
+                       msg_print("¥¹¥Ñ¥¤¥¯¤¬Éߤ«¤ì¤¿Íî¤Ȥ··ê¤ËÍî¤Á¤Æ¤·¤Þ¤Ã¤¿¡ª");
 #else
                                msg_print("You fall into a spiked pit!");
 #endif
@@ -1249,7 +1249,7 @@ static void hit_trap(bool break_trap)
                                dam = damroll(2, 6);
 
 #ifdef JP
-                               name = "Í·ê";
+                               name = "Íî¤Ȥ··ê";
 #else
                                name = "a pit trap";
 #endif
@@ -1266,7 +1266,7 @@ static void hit_trap(bool break_trap)
 
 
 #ifdef JP
-                                       name = "¥È¥²¤Î¤¢¤ëÍ·ê";
+                                       name = "¥È¥²¤Î¤¢¤ëÍî¤Ȥ··ê";
 #else
                                        name = "a spiked pit";
 #endif
@@ -1299,7 +1299,7 @@ static void hit_trap(bool break_trap)
                        break;
                }
 
-               case FEAT_TRAP_TY_CURSE:
+               case TRAP_TY_CURSE:
                {
 #ifdef JP
                        msg_print("²¿¤«¤¬¥Ô¥«¥Ã¤È¸÷¤Ã¤¿¡ª");
@@ -1327,7 +1327,7 @@ static void hit_trap(bool break_trap)
                        break;
                }
 
-               case FEAT_TRAP_TELEPORT:
+               case TRAP_TELEPORT:
                {
 #ifdef JP
                        msg_print("¥Æ¥ì¥Ý¡¼¥È¡¦¥È¥é¥Ã¥×¤Ë¤Ò¤Ã¤«¤«¤Ã¤¿¡ª");
@@ -1335,11 +1335,11 @@ static void hit_trap(bool break_trap)
                        msg_print("You hit a teleport trap!");
 #endif
 
-                       teleport_player(100, TRUE);
+                       teleport_player(100, TELEPORT_PASSIVE);
                        break;
                }
 
-               case FEAT_TRAP_FIRE:
+               case TRAP_FIRE:
                {
 #ifdef JP
                        msg_print("±ê¤ËÊñ¤Þ¤ì¤¿¡ª");
@@ -1357,7 +1357,7 @@ static void hit_trap(bool break_trap)
                        break;
                }
 
-               case FEAT_TRAP_ACID:
+               case TRAP_ACID:
                {
 #ifdef JP
                        msg_print("»À¤¬¿á¤­¤«¤±¤é¤ì¤¿¡ª");
@@ -1375,7 +1375,7 @@ static void hit_trap(bool break_trap)
                        break;
                }
 
-               case FEAT_TRAP_SLOW:
+               case TRAP_SLOW:
                {
                        if (check_hit(125))
                        {
@@ -1401,7 +1401,7 @@ static void hit_trap(bool break_trap)
                        break;
                }
 
-               case FEAT_TRAP_LOSE_STR:
+               case TRAP_LOSE_STR:
                {
                        if (check_hit(125))
                        {
@@ -1432,7 +1432,7 @@ static void hit_trap(bool break_trap)
                        break;
                }
 
-               case FEAT_TRAP_LOSE_DEX:
+               case TRAP_LOSE_DEX:
                {
                        if (check_hit(125))
                        {
@@ -1463,7 +1463,7 @@ static void hit_trap(bool break_trap)
                        break;
                }
 
-               case FEAT_TRAP_LOSE_CON:
+               case TRAP_LOSE_CON:
                {
                        if (check_hit(125))
                        {
@@ -1494,7 +1494,7 @@ static void hit_trap(bool break_trap)
                        break;
                }
 
-               case FEAT_TRAP_BLIND:
+               case TRAP_BLIND:
                {
 #ifdef JP
                        msg_print("¹õ¤¤¥¬¥¹¤ËÊñ¤ß¹þ¤Þ¤ì¤¿¡ª");
@@ -1509,7 +1509,7 @@ static void hit_trap(bool break_trap)
                        break;
                }
 
-               case FEAT_TRAP_CONFUSE:
+               case TRAP_CONFUSE:
                {
 #ifdef JP
                        msg_print("¤­¤é¤á¤¯¥¬¥¹¤ËÊñ¤ß¹þ¤Þ¤ì¤¿¡ª");
@@ -1524,7 +1524,7 @@ static void hit_trap(bool break_trap)
                        break;
                }
 
-               case FEAT_TRAP_POISON:
+               case TRAP_POISON:
                {
 #ifdef JP
                        msg_print("»É·ãŪ¤ÊÎп§¤Î¥¬¥¹¤ËÊñ¤ß¹þ¤Þ¤ì¤¿¡ª");
@@ -1539,7 +1539,7 @@ static void hit_trap(bool break_trap)
                        break;
                }
 
-               case FEAT_TRAP_SLEEP:
+               case TRAP_SLEEP:
                {
 #ifdef JP
                        msg_print("´ñ̯¤ÊÇò¤¤Ì¸¤ËÊñ¤Þ¤ì¤¿¡ª");
@@ -1579,7 +1579,7 @@ msg_print("
                        break;
                }
 
-               case FEAT_TRAP_TRAPS:
+               case TRAP_TRAPS:
                {
 #ifdef JP
 msg_print("¤Þ¤Ð¤æ¤¤Á®¸÷¤¬Áö¤Ã¤¿¡ª");
@@ -1593,7 +1593,7 @@ msg_print("
                        break;
                }
 
-               case FEAT_TRAP_ALARM:
+               case TRAP_ALARM:
                {
 #ifdef JP
                        msg_print("¤±¤¿¤¿¤Þ¤·¤¤²»¤¬ÌĤê¶Á¤¤¤¿¡ª");
@@ -1606,7 +1606,7 @@ msg_print("
                        break;
                }
 
-               case FEAT_TRAP_OPEN:
+               case TRAP_OPEN:
                {
 #ifdef JP
                        msg_print("Âç²»¶Á¤È¶¦¤Ë¤Þ¤ï¤ê¤ÎÊɤ¬Êø¤ì¤¿¡ª");
@@ -1621,7 +1621,7 @@ msg_print("
                        break;
                }
 
-               case FEAT_TRAP_ARMAGEDDON:
+               case TRAP_ARMAGEDDON:
                {
                        static int levs[10] = {0, 0, 20, 10, 5, 3, 2, 1, 1, 1};
                        int evil_idx = 0, good_idx = 0;
@@ -1671,7 +1671,7 @@ msg_print("
                        break;
                }
 
-               case FEAT_TRAP_PIRANHA:
+               case TRAP_PIRANHA:
                {
 #ifdef JP
                        msg_print("ÆÍÁ³Êɤ«¤é¿å¤¬°î¤ì½Ð¤·¤¿¡ª¥Ô¥é¥Ë¥¢¤¬¤¤¤ë¡ª");
@@ -2010,7 +2010,7 @@ static void py_attack_aux(int y, int x, bool *fear, bool *mdeath, s16b hand, int
                        if (p_ptr->monlite && (mode != HISSATSU_NYUSIN)) tmp /= 3;
                        if (p_ptr->cursed & TRC_AGGRAVATE) tmp /= 2;
                        if (r_ptr->level > (p_ptr->lev * p_ptr->lev / 20 + 10)) tmp /= 3;
-                       if (m_ptr->csleep && m_ptr->ml)
+                       if (MON_CSLEEP(m_ptr) && m_ptr->ml)
                        {
                                /* Can't backstab creatures that we can't see, right? */
                                backstab = TRUE;
@@ -2019,7 +2019,7 @@ static void py_attack_aux(int y, int x, bool *fear, bool *mdeath, s16b hand, int
                        {
                                fuiuchi = TRUE;
                        }
-                       else if (m_ptr->monfear && m_ptr->ml)
+                       else if (MON_MONFEAR(m_ptr) && m_ptr->ml)
                        {
                                stab_fleeing = TRUE;
                        }
@@ -2029,7 +2029,7 @@ static void py_attack_aux(int y, int x, bool *fear, bool *mdeath, s16b hand, int
        case CLASS_MONK:
        case CLASS_FORCETRAINER:
        case CLASS_BERSERKER:
-               if (empty_hands(TRUE) & EMPTY_HAND_RARM) monk_attack = TRUE;
+               if ((empty_hands(TRUE) & EMPTY_HAND_RARM) && !p_ptr->riding) monk_attack = TRUE;
                break;
        }
 
@@ -2071,13 +2071,8 @@ static void py_attack_aux(int y, int x, bool *fear, bool *mdeath, s16b hand, int
                }
        }
 
-       if (m_ptr->csleep)
-       {
-               /* Disturb the monster */
-               m_ptr->csleep = 0;
-               mproc_remove(c_ptr->m_idx, m_ptr->mproc_idx[MPROC_CSLEEP], MPROC_CSLEEP);
-               if (r_ptr->flags7 & RF7_HAS_LD_MASK) p_ptr->update |= (PU_MON_LITE);
-       }
+       /* Disturb the monster */
+       (void)set_monster_csleep(c_ptr->m_idx, 0);
 
        /* Extract monster name (or "it") */
        monster_desc(m_name, m_ptr, 0);
@@ -2344,25 +2339,22 @@ static void py_attack_aux(int y, int x, bool *fear, bool *mdeath, s16b hand, int
                                {
                                        if (p_ptr->lev > randint1(r_ptr->level + resist_stun + 10))
                                        {
-                                               if (m_ptr->stunned)
+                                               if (set_monster_stunned(c_ptr->m_idx, stun_effect + MON_STUNNED(m_ptr)))
                                                {
 #ifdef JP
-                                                       msg_format("%^s¤Ï¤µ¤é¤Ë¥Õ¥é¥Õ¥é¤Ë¤Ê¤Ã¤¿¡£", m_name);
+                                                       msg_format("%^s¤Ï¥Õ¥é¥Õ¥é¤Ë¤Ê¤Ã¤¿¡£", m_name);
 #else
-                                                       msg_format("%^s is more stunned.", m_name);
+                                                       msg_format("%^s is stunned.", m_name);
 #endif
                                                }
                                                else
                                                {
 #ifdef JP
-                                                       msg_format("%^s¤Ï¥Õ¥é¥Õ¥é¤Ë¤Ê¤Ã¤¿¡£", m_name);
+                                                       msg_format("%^s¤Ï¤µ¤é¤Ë¥Õ¥é¥Õ¥é¤Ë¤Ê¤Ã¤¿¡£", m_name);
 #else
-                                                       msg_format("%^s is stunned.", m_name);
+                                                       msg_format("%^s is more stunned.", m_name);
 #endif
-                                                       mproc_add(c_ptr->m_idx, MPROC_STUNNED);
                                                }
-
-                                               m_ptr->stunned = MIN(stun_effect + m_ptr->stunned, 200);
                                        }
                                }
                        }
@@ -2524,7 +2516,7 @@ static void py_attack_aux(int y, int x, bool *fear, bool *mdeath, s16b hand, int
                                if (!(r_ptr->flags3 & (RF3_NO_STUN)))
                                {
                                        /* Get stunned */
-                                       if (m_ptr->stunned)
+                                       if (MON_STUNNED(m_ptr))
                                        {
 #ifdef JP
                                                msg_format("%s¤Ï¤Ò¤É¤¯¤â¤¦¤í¤¦¤È¤·¤¿¡£", m_name);
@@ -2541,11 +2533,10 @@ static void py_attack_aux(int y, int x, bool *fear, bool *mdeath, s16b hand, int
 #else
                                                msg_format("%s is dazed.", m_name);
 #endif
-                                               mproc_add(c_ptr->m_idx, MPROC_STUNNED);
                                        }
 
                                        /* Apply stun */
-                                       m_ptr->stunned = (tmp < 200) ? tmp : 200;
+                                       (void)set_monster_stunned(c_ptr->m_idx, MON_STUNNED(m_ptr) + tmp);
                                }
                                else
                                {
@@ -2735,6 +2726,7 @@ static void py_attack_aux(int y, int x, bool *fear, bool *mdeath, s16b hand, int
                                }
                                m_ptr->maxhp -= (k+7)/8;
                                if (m_ptr->hp > m_ptr->maxhp) m_ptr->hp = m_ptr->maxhp;
+                               if (m_ptr->maxhp < 1) m_ptr->maxhp = 1;
                                weak = TRUE;
                        }
                        can_drain = FALSE;
@@ -2779,16 +2771,13 @@ static void py_attack_aux(int y, int x, bool *fear, bool *mdeath, s16b hand, int
                                }
                                else
                                {
-                                       int tmp = m_ptr->confused + 10 + randint0(p_ptr->lev) / 5;
-
 #ifdef JP
                                        msg_format("%^s¤Ïº®Í𤷤¿¤è¤¦¤À¡£", m_name);
 #else
                                        msg_format("%^s appears confused.", m_name);
 #endif
 
-                                       m_ptr->confused = (tmp < 200) ? tmp : 200;
-                                       if (!m_ptr->mproc_idx[MPROC_CONFUSED]) mproc_add(c_ptr->m_idx, MPROC_CONFUSED);
+                                       (void)set_monster_confused(c_ptr->m_idx, MON_CONFUSED(m_ptr) + 10 + randint0(p_ptr->lev) / 5);
                                }
                        }
 
@@ -2830,7 +2819,7 @@ static void py_attack_aux(int y, int x, bool *fear, bool *mdeath, s16b hand, int
                                        msg_format("%^s disappears!", m_name);
 #endif
 
-                                       teleport_away(c_ptr->m_idx, 50, FALSE, TRUE);
+                                       teleport_away(c_ptr->m_idx, 50, TELEPORT_PASSIVE);
                                        num = num_blow + 1; /* Can't hit it anymore! */
                                        *mdeath = TRUE;
                                }
@@ -3183,19 +3172,14 @@ bool py_attack(int y, int x, int mode)
                        msg_format ("There is something scary in your way!");
 #endif
 
-               if (m_ptr->csleep)
-               {
-                       /* Disturb the monster */
-                       m_ptr->csleep = 0;
-                       mproc_remove(c_ptr->m_idx, m_ptr->mproc_idx[MPROC_CSLEEP], MPROC_CSLEEP);
-                       if (r_ptr->flags7 & RF7_HAS_LD_MASK) p_ptr->update |= (PU_MON_LITE);
-               }
+               /* Disturb the monster */
+               (void)set_monster_csleep(c_ptr->m_idx, 0);
 
                /* Done */
                return FALSE;
        }
 
-       if (m_ptr->csleep) /* It is not honorable etc to attack helpless victims */
+       if (MON_CSLEEP(m_ptr)) /* It is not honorable etc to attack helpless victims */
        {
                if (!(r_ptr->flags3 & RF3_EVIL) || one_in_(5)) chg_virtue(V_COMPASSION, -1);
                if (!(r_ptr->flags3 & RF3_EVIL) || one_in_(5)) chg_virtue(V_HONOUR, -1);
@@ -3300,8 +3284,8 @@ bool pattern_seq(int c_y, int c_x, int n_y, int n_x)
 
        if (!is_pattern_tile_cur && !is_pattern_tile_new) return TRUE;
 
-       pattern_type_cur = is_pattern_tile_cur ? cur_f_ptr->power : NOT_PATTERN_TILE;
-       pattern_type_new = is_pattern_tile_new ? new_f_ptr->power : NOT_PATTERN_TILE;
+       pattern_type_cur = is_pattern_tile_cur ? cur_f_ptr->subtype : NOT_PATTERN_TILE;
+       pattern_type_new = is_pattern_tile_new ? new_f_ptr->subtype : NOT_PATTERN_TILE;
 
        if (pattern_type_new == PATTERN_TILE_START)
        {
@@ -3706,33 +3690,37 @@ bool move_player_effect(int ny, int nx, u32b mpe_mode)
 
 bool trap_can_be_ignored(int feat)
 {
-       switch (feat)
+       feature_type *f_ptr = &f_info[feat];
+
+       if (!have_flag(f_ptr->flags, FF_TRAP)) return TRUE;
+
+       switch (f_ptr->subtype)
        {
-       case FEAT_TRAP_TRAPDOOR:
-       case FEAT_TRAP_PIT:
-       case FEAT_TRAP_SPIKED_PIT:
-       case FEAT_TRAP_POISON_PIT:
+       case TRAP_TRAPDOOR:
+       case TRAP_PIT:
+       case TRAP_SPIKED_PIT:
+       case TRAP_POISON_PIT:
                if (p_ptr->levitation) return TRUE;
                break;
-       case FEAT_TRAP_TELEPORT:
+       case TRAP_TELEPORT:
                if (p_ptr->anti_tele) return TRUE;
                break;
-       case FEAT_TRAP_FIRE:
+       case TRAP_FIRE:
                if (p_ptr->immune_fire) return TRUE;
                break;
-       case FEAT_TRAP_ACID:
+       case TRAP_ACID:
                if (p_ptr->immune_acid) return TRUE;
                break;
-       case FEAT_TRAP_BLIND:
+       case TRAP_BLIND:
                if (p_ptr->resist_blind) return TRUE;
                break;
-       case FEAT_TRAP_CONFUSE:
+       case TRAP_CONFUSE:
                if (p_ptr->resist_conf) return TRUE;
                break;
-       case FEAT_TRAP_POISON:
+       case TRAP_POISON:
                if (p_ptr->resist_pois) return TRUE;
                break;
-       case FEAT_TRAP_SLEEP:
+       case TRAP_SLEEP:
                if (p_ptr->free_act) return TRUE;
                break;
        }
@@ -3881,7 +3869,7 @@ void move_player(int dir, bool do_pickup, bool break_trap)
 
        /* Player can not walk through "walls"... */
        /* unless in Shadow Form */
-       p_can_kill_walls = p_ptr->kill_wall && have_flag(f_ptr->flags, FF_TUNNEL) &&
+       p_can_kill_walls = p_ptr->kill_wall && have_flag(f_ptr->flags, FF_HURT_DISI) &&
                (!p_can_enter || !have_flag(f_ptr->flags, FF_LOS)) &&
                !have_flag(f_ptr->flags, FF_PERMANENT);
 
@@ -3896,13 +3884,8 @@ void move_player(int dir, bool do_pickup, bool break_trap)
                    ((p_ptr->muta2 & MUT2_BERS_RAGE) && p_ptr->shero)) &&
                    pattern_seq(py, px, y, x) && (p_can_enter || p_can_kill_walls))
                {
-                       if (m_ptr->csleep)
-                       {
-                               /* Disturb the monster */
-                               m_ptr->csleep = 0;
-                               mproc_remove(c_ptr->m_idx, m_ptr->mproc_idx[MPROC_CSLEEP], MPROC_CSLEEP);
-                               if (r_ptr->flags7 & RF7_HAS_LD_MASK) p_ptr->update |= (PU_MON_LITE);
-                       }
+                       /* Disturb the monster */
+                       (void)set_monster_csleep(c_ptr->m_idx, 0);
 
                        /* Extract monster name (or "it") */
                        monster_desc(m_name, m_ptr, 0);
@@ -3960,7 +3943,7 @@ void move_player(int dir, bool do_pickup, bool break_trap)
                        oktomove = FALSE;
                        disturb(0, 0);
                }
-               else if (riding_m_ptr->monfear)
+               else if (MON_MONFEAR(riding_m_ptr))
                {
                        char m_name[80];
 
@@ -4025,7 +4008,7 @@ void move_player(int dir, bool do_pickup, bool break_trap)
                        disturb(0, 0);
                }
 
-               if (oktomove && riding_m_ptr->stunned && one_in_(2))
+               if (oktomove && MON_STUNNED(riding_m_ptr) && one_in_(2))
                {
                        char m_name[80];
                        monster_desc(m_name, riding_m_ptr, 0);
@@ -4063,7 +4046,7 @@ void move_player(int dir, bool do_pickup, bool break_trap)
         */
        else if (have_flag(f_ptr->flags, FF_TREE) && !p_can_kill_walls)
        {
-               if ((p_ptr->pclass != CLASS_RANGER) && !p_ptr->levitation) energy_use *= 2;
+               if ((p_ptr->pclass != CLASS_RANGER) && !p_ptr->levitation && (!p_ptr->riding || !(riding_r_ptr->flags8 & RF8_WILD_WOOD))) energy_use *= 2;
        }
 
 #ifdef ALLOW_EASY_DISARM /* TNB */