OSDN Git Service

[Refactor] #41156 Conflict 対策に have_flag() を has_flag() へ / Rename have_flag() to...
[hengband/hengband.git] / src / floor / pattern-walk.c
index 39bc25a..7d3c151 100644 (file)
@@ -1,18 +1,28 @@
 #include "floor/pattern-walk.h"
 #include "cmd-io/cmd-save.h"
+#include "core/asking-player.h"
 #include "dungeon/dungeon.h"
 #include "dungeon/quest.h"
+#include "floor/cave.h"
+#include "floor/floor-mode-changer.h"
 #include "game-option/birth-options.h"
 #include "game-option/play-record-options.h"
 #include "game-option/special-options.h"
+#include "grid/grid.h"
+#include "io/input-key-requester.h"
 #include "io/write-diary.h"
 #include "player/player-damage.h"
-#include "player/player-effects.h"
 #include "player/player-move.h"
 #include "player/player-race-types.h"
-#include "realm/realm-song-numbers.h"
+#include "player/player-race.h"
 #include "spell/spells-status.h"
 #include "spell-kind/spells-teleport.h"
+#include "status/bad-status-setter.h"
+#include "status/experience.h"
+#include "system/floor-type-definition.h"
+#include "util/bit-flags-calculator.h"
+#include "view/display-messages.h"
+#include "world/world.h"
 
 /*!
  * @brief パターン終点到達時のテレポート処理を行う
@@ -121,17 +131,115 @@ bool pattern_effect(player_type *creature_ptr)
         break;
 
     case PATTERN_TILE_WRECKED:
-        if (!IS_INVULN(creature_ptr))
+        if (!is_invuln(creature_ptr))
             take_hit(creature_ptr, DAMAGE_NOESCAPE, 200, _("壊れた「パターン」を歩いたダメージ", "walking the corrupted Pattern"), -1);
         break;
 
     default:
         if (is_specific_player_race(creature_ptr, RACE_AMBERITE) && !one_in_(2))
             return TRUE;
-        else if (!IS_INVULN(creature_ptr))
+        else if (!is_invuln(creature_ptr))
             take_hit(creature_ptr, DAMAGE_NOESCAPE, damroll(1, 3), _("「パターン」を歩いたダメージ", "walking the Pattern"), -1);
         break;
     }
 
     return TRUE;
 }
+
+/*!
+ * @brief パターンによる移動制限処理
+ * @param creature_ptr プレーヤーへの参照ポインタ
+ * @param c_y プレイヤーの移動元Y座標
+ * @param c_x プレイヤーの移動元X座標
+ * @param n_y プレイヤーの移動先Y座標
+ * @param n_x プレイヤーの移動先X座標
+ * @return 移動処理が可能である場合(可能な場合に選択した場合)TRUEを返す。
+ */
+bool pattern_seq(player_type *creature_ptr, POSITION c_y, POSITION c_x, POSITION n_y, POSITION n_x)
+{
+    feature_type *cur_f_ptr = &f_info[creature_ptr->current_floor_ptr->grid_array[c_y][c_x].feat];
+    feature_type *new_f_ptr = &f_info[creature_ptr->current_floor_ptr->grid_array[n_y][n_x].feat];
+    bool is_pattern_tile_cur = has_flag(cur_f_ptr->flags, FF_PATTERN);
+    bool is_pattern_tile_new = has_flag(new_f_ptr->flags, FF_PATTERN);
+    if (!is_pattern_tile_cur && !is_pattern_tile_new)
+        return TRUE;
+
+    int pattern_type_cur = is_pattern_tile_cur ? cur_f_ptr->subtype : NOT_PATTERN_TILE;
+    int pattern_type_new = is_pattern_tile_new ? new_f_ptr->subtype : NOT_PATTERN_TILE;
+    if (pattern_type_new == PATTERN_TILE_START) {
+        if (!is_pattern_tile_cur && !creature_ptr->confused && !creature_ptr->stun && !creature_ptr->image) {
+            if (get_check(_("パターンの上を歩き始めると、全てを歩かなければなりません。いいですか?",
+                    "If you start walking the Pattern, you must walk the whole way. Ok? ")))
+                return TRUE;
+            else
+                return FALSE;
+        } else
+            return TRUE;
+    }
+
+    if ((pattern_type_new == PATTERN_TILE_OLD) || (pattern_type_new == PATTERN_TILE_END) || (pattern_type_new == PATTERN_TILE_WRECKED)) {
+        if (is_pattern_tile_cur) {
+            return TRUE;
+        } else {
+            msg_print(_("パターンの上を歩くにはスタート地点から歩き始めなくてはなりません。", "You must start walking the Pattern from the startpoint."));
+            return FALSE;
+        }
+    }
+
+    if ((pattern_type_new == PATTERN_TILE_TELEPORT) || (pattern_type_cur == PATTERN_TILE_TELEPORT))
+        return TRUE;
+
+    if (pattern_type_cur == PATTERN_TILE_START) {
+        if (is_pattern_tile_new)
+            return TRUE;
+        else {
+            msg_print(_("パターンの上は正しい順序で歩かねばなりません。", "You must walk the Pattern in correct order."));
+            return FALSE;
+        }
+    }
+
+    if ((pattern_type_cur == PATTERN_TILE_OLD) || (pattern_type_cur == PATTERN_TILE_END) || (pattern_type_cur == PATTERN_TILE_WRECKED)) {
+        if (!is_pattern_tile_new) {
+            msg_print(_("パターンを踏み外してはいけません。", "You may not step off from the Pattern."));
+            return FALSE;
+        } else {
+            return TRUE;
+        }
+    }
+
+    if (!is_pattern_tile_cur) {
+        msg_print(_("パターンの上を歩くにはスタート地点から歩き始めなくてはなりません。", "You must start walking the Pattern from the startpoint."));
+
+        return FALSE;
+    }
+
+    byte ok_move = PATTERN_TILE_START;
+    switch (pattern_type_cur) {
+    case PATTERN_TILE_1:
+        ok_move = PATTERN_TILE_2;
+        break;
+    case PATTERN_TILE_2:
+        ok_move = PATTERN_TILE_3;
+        break;
+    case PATTERN_TILE_3:
+        ok_move = PATTERN_TILE_4;
+        break;
+    case PATTERN_TILE_4:
+        ok_move = PATTERN_TILE_1;
+        break;
+    default:
+        if (current_world_ptr->wizard)
+            msg_format(_("おかしなパターン歩行、%d。", "Funny Pattern walking, %d."), pattern_type_cur);
+        return TRUE;
+    }
+
+    if ((pattern_type_new == ok_move) || (pattern_type_new == pattern_type_cur))
+        return TRUE;
+
+    if (!is_pattern_tile_new)
+        msg_print(_("パターンを踏み外してはいけません。", "You may not step off from the Pattern."));
+    else
+        msg_print(_("パターンの上は正しい順序で歩かねばなりません。", "You must walk the Pattern in correct order."));
+
+    return FALSE;
+}